# Typ3 osa / PNC iPCL System Description and Programming Manual



Rexroth Bosch Group Тур3 osa / PNC

# iPCL System Description and Programming Manual

1070 073 875-101 (02.04) GB

Software release: V7.x



© 2002

by Bosch Rexroth AG, Erbach / Germany All rights reserved, including applications for protective rights. Reproduction or distribution by any means subject to our prior written permission.

Discretionary charge 12.- EUR

# Contents

# Page

V

| <b>1</b><br>1.1<br>1.2<br>1.3<br>1.4<br>1.5<br>1.6                                                                                         | Safety InstructionsIntended useQualified personnelSafety markings on productsSafety instructions in this manualSafety instructions for the described productDocumentation, software release and trademarks                                                                                                                                                                                  | <b>1–1</b><br>1–1<br>1–2<br>1–3<br>1–4<br>1–5<br>1–7                                                                                      |
|--------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| <b>2</b><br>2.1<br>2.2<br>2.3<br>2.4                                                                                                       | System Overview<br>Functionality<br>Hardware platforms<br>iPCL extensions<br>Data backup                                                                                                                                                                                                                                                                                                    | <b>2–1</b><br>2–2<br>2–3<br>2–4                                                                                                           |
| <b>3</b><br>3.1<br>3.2<br>3.2.1<br>3.2.2<br>3.2.3<br>3.3<br>3.3.1<br>3.3.2<br>3.3.3<br>3.3.4<br>3.3.5<br>3.3.6                             | ConfigurationConnecting to the systemStartup of the iPCLInitialization of the iPCLStartup diagramStartup conditionsData backup and residual characteristics of the iPCLData backup depending on hardware platformDefining residual areas in the OM2Residual characteristics depending on hardware platformResidual operationNon-residual operationBuffer failure, data backup fault         | <b>3–1</b><br>3–1<br>3–2<br>3–3<br>3–4<br>3–7<br>3–9<br>3–9<br>3–12<br>3–14<br>3–15<br>3–15<br>3–16                                       |
| <b>4</b><br>4.1<br>4.2                                                                                                                     | <b>Peripheral Operation</b> Data exchange machine <—> PLC PROFIBUS-DP                                                                                                                                                                                                                                                                                                                       | <b>4–1</b><br>4–1<br>4–2                                                                                                                  |
| <b>5</b><br>5.1<br>5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.3.4<br>5.5<br>5.6<br>5.6.1<br>5.6.2<br>5.6.3<br>5.6.4<br>5.7<br>5.7.1<br>5.8 | Programming Basics<br>Program Structure<br>Module Types<br>Organization modules (OM)<br>Program modules<br>Data modules<br>APS modules<br>Program Processing<br>Time Monitoring<br>I/O state<br>Fixing inputs, outputs & markers<br>Updating timers<br>Cyclical processing<br>Application program structure<br>Initialisation table OM2<br>Printout of the OM2iPCL<br>Module reference list | <b>5–1</b><br>5–1<br>5–2<br>5–2<br>5–3<br>5–3<br>5–3<br>5–4<br>5–6<br>5–6<br>5–6<br>5–6<br>5–6<br>5–7<br>5–7<br>5–7<br>5–8<br>5–9<br>5–14 |

| 5.9    | Module existence                                       | 5–15 |
|--------|--------------------------------------------------------|------|
| 5.10   | Module size                                            | 5–15 |
| 5.11   | Module start address                                   | 5–16 |
| 5.12   | Module header                                          | 5–16 |
| 5.13   | OM9 error module                                       | 5–17 |
| 5.14   | Fixation                                               | 5–17 |
| 5.15   | Parameterized Modules                                  | 5–18 |
| 5.16   | Time-controlled program processing                     | 5–19 |
| 5.17   | Application stack                                      | 5–20 |
| 6      | iPCL addressing                                        | 6–1  |
| 6.1    | Operand & module identifiers, module list              | 6–1  |
| 6.2    | Assignments in the special marker area                 | 6–2  |
| 6.3    | System area assignment                                 | 6–4  |
| 6.4    | Periphery status                                       | 6–6  |
| 6.5    | Data formats                                           | 6–7  |
| 6.6    | Register structure                                     | 6–11 |
| 6.7    | Representation of constants                            | 6–12 |
| 6.8    | Program module calls                                   | 6–12 |
| 6.9    | Jump instructions                                      | 6–12 |
| 6.10   | Bit- and module addresses                              | 6–13 |
| 6.11   | Byte addresses                                         | 6–13 |
| 6.12   | Addressing modes                                       | 6–14 |
| 6.12.1 | Absolute addressable operands                          | 6–14 |
| 6.12.2 | Direct addressing of all absolute addressable operands | 6–14 |
| 6.12.3 | Register-to-register addressing                        | 6–14 |
| 6.12.4 | Register indirect addressing                           | 6–15 |
| 6.12.5 | iPCL indirect addressing                               | 6–16 |
| 6.13   | Parameter transfer                                     | 6–18 |
| 6.14   | Addressing limits                                      | 6–19 |
| 7      | Instruction set                                        | 7–1  |
| 7.1    | Structure of controller instructions                   | 7–1  |
| 7.2    | Flags                                                  | 7–1  |
| 7.3    | Key to abbreviations                                   | 7–2  |
| 7.4    | Bit instructions                                       | 7–3  |
|        |                                                        |      |

| 7.2    | Flags                                           | 7–1  |
|--------|-------------------------------------------------|------|
| 7.3    | Key to abbreviations                            | 7–2  |
| 7.4    | Bit instructions                                | 7–3  |
| 7.5    | Timer programming                               | 7–4  |
| 7.5.1  | Timer instructions                              | 7–5  |
| 7.5.2  | Time format                                     | 7–6  |
| 7.5.3  | Timer diagrams                                  | 7–7  |
| 7.6    | Counter instructions                            | 7–8  |
| 7.7    | Digital links                                   | 7–9  |
| 7.8    | SWAP instructions                               | 7–9  |
| 7.9    | Compare instruction                             | 7–10 |
| 7.10   | Load instructions                               | 7–12 |
| 7.11   | Tranfer instructions                            | 7–13 |
| 7.12   | Convert instructions                            | 7–14 |
| 7.13   | Increment & Decrement instructions              | 7–15 |
| 7.14   | Stack instructions                              | 7–15 |
| 7.15   | No operation instructions & CARRY manipulations | 7–15 |
| 7.16   | Shift instructions                              | 7–16 |
| 7.17   | Rotate instructions                             | 7–17 |
| 7.18   | Fixed point arithmetic                          | 7–18 |
| 7.18.1 | Add instructions                                | 7–18 |
| 7.18.2 | Substract instructions                          | 7–20 |
| 7.18.3 | Multiply instructions                           | 7–22 |
| 7.18.4 | Divide instructions                             | 7–23 |

| 7.19.2       TRANSFERfloating point values       7-24         7.19.3       CONVERT number formats (floating point <-> integer)       7-24         7.19.4       Convert data formats (fleAL <-> LREAL)       7-24         7.19.5       Removing decimal positions       7-22         7.19.6       Comparefloating point values       7-22         7.19.7       Calculating with floating point values       7-22         7.19.8       Forming absolute value       7-22         7.19.9       Extracting square root       7-22         7.19.10       Exponentiation       7-22         7.19.11       Logarithmic functions       7-33         7.20       Parameter assignments       7-33         7.21       Local symbol names & auxiliary markers for program tracking       7-33         7.22       System variable       7-33         7.23       Jump instructions       7-33         7.24       Module calls       7-33         7.25       End of module instruction       7-34         7.26       FIFO instructions       7-34         7.28       Interrupt instructions for time-controlled processing       7-44         7.26       FIFO instructions for time-controlled processing       7-44         7.30                                       | 7.19    | Floating point arithmetic                                     | 7–24 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------------------------------------------------------------|------|
| 7.19.3       CONVERT number formats (floating point <-> integer)       7-24         7.19.4       Convert data formats (REAL <> LREAL)       7-21         7.19.5       Removing decimal positions       7-22         7.19.6       Comparefloating point values       7-22         7.19.7       Calculating with floating point values       7-22         7.19.8       Forming absolute value       7-24         7.19.9       Extracting square root       7-22         7.19.1       Logarithmic functions       7-32         7.19.1       Logarithmic functions floating point       7-33         7.19.1       Trigonometric functions floating point       7-34         7.19.1       Logarithmic functions       7-33         7.20       Parameter assignments       7-33         7.21       Local symbol names & auxiliary markers for program tracking       7-33         7.22       System variable       7-34         7.23       Jump instructions       7-34         7.24       Module calls       7-34         7.25       End of module instruction       7-34         7.26       FIFO instructions for time-controlled processing       7-44         7.29       Program stop and program end       7-44         7.                                 |         |                                                               | 7–25 |
| 7.19.4       Convert data formats (REAL <> LREAL)       7-24         7.19.5       Removing decimal positions       7-27         7.19.6       Comparefloating point values       7-22         7.19.7       Calculating with floating point values       7-22         7.19.8       Forming absolute value       7-22         7.19.7       Calculating with floating point values       7-24         7.19.8       Forming absolute value       7-24         7.19.9       Extracting square root       7-24         7.19.10       Exponentiation       7-24         7.19.11       Logarithmic functions       7-34         7.20       Parameter assignments       7-33         7.21       Local symbol names & auxiliary markers for program tracking       7-33         7.22       System variable       7-33         7.23       Jump instructions       7-33         7.24       Module calls       7-33         7.25       End of module instruction       7-33         7.26       FIFO instructions for time-controlled processing       7-44         7.25       End of module instruction s for time-controlled processing       7-44         7.29       Program stop and program end       7-44         7.30                                             |         |                                                               |      |
| 7.19.5       Removing decimal positions       7-22         7.19.6       Comparefloating point values       7-22         7.19.7       Calculating with floating point values       7-22         7.19.8       Forming absolute value       7-22         7.19.9       Extracting square root       7-22         7.19.10       Exponentiation       7-22         7.19.11       Logarithmic functions       7-33         7.20       Parameter assignments       7-33         7.21       Local symbol names & auxiliary markers for program tracking       7-33         7.22       System variable       7-33         7.23       Jump instructions       7-33         7.24       Module calls       7-33         7.25       End of module instruction       7-34         7.26       FiFO instructions       7-34         7.27       Block commands       7-34         7.28       Interrupt instructions for time-controlled processing       7-44         7.29       Program stop and program end       7-44         7.29       Program stop and program end       7-44         7.30       Backing up and loading residual areas       9-4         9.1       Indirect addressing       9-4                                                                      |         |                                                               |      |
| 7.19.6       Comparefloating point values       7-22         7.19.7       Calculating with floating point values       7-24         7.19.8       Forming absolute value       7-24         7.19.9       Extracting square root       7-24         7.19.10       Exponentiation       7-24         7.19.11       Logarithmic functions       7-30         7.19.12       Trigonometric functions floating point       7-33         7.20       Parameter assignments       7-33         7.21       Local symbol names & auxiliary markers for program tracking       7-33         7.22       System variable       7-33         7.23       Jump instructions       7-34         7.24       Module calls       7-33         7.25       End of module instruction       7-34         7.26       FIFO instructions for time-controlled processing       7-44         7.29       Program stop and program end       7-44         7.29       Program stop and program end       7-44         7.30       Backing up and loading residual areas       7-44         8       Processing Times       9-1         9.1       Indirect addressing       9-2         9.2       Compare instruction examples       9-3                                                      |         |                                                               | 7–26 |
| 7.19.7Calculating with floating point values7-247.19.8Forming absolute value7-287.19.9Extracting square root7-287.19.10Exponentiation7-287.19.11Logarithmic functions7-367.19.12Trigonometric functions floating point7-367.19.12Trigonometric functions floating point7-377.20Parameter assignments7-377.21Local symbol names & auxiliary markers for program tracking7-377.22System variable7-337.23Jump instructions7-367.24Module calls7-337.25End of module instruction7-367.26FIFO instructions for time-controlled processing7-377.27Block commands7-377.28Interrupt instructions for time-controlled processing7-477.30Backing up and loading residual areas7-478Processing Times9-19.1Indirect addressing9-19.2Compare instruction examples9-39.3FIFO instruction examples9-39.3FIFO instruction examples9-3                                                                                                                                                                                                                                                                                                                                                                                                                                     |         |                                                               | 7–27 |
| 7.19.8Forming absolute value7-247.19.9Extracting square root7-227.19.10Exponentiation7-227.19.11Logarithmic functions7-307.19.12Trigonometric functions floating point7-337.20Parameter assignments7-337.21Local symbol names & auxiliary markers for program tracking7-337.22System variable7-337.23Jump instructions7-337.24Module calls7-337.25End of module instruction7-337.26FIFO instructions7-337.27Block commands7-337.28Interrupt instructions for time-controlled processing7-447.29Program stop and program end7-447.30Backing up and loading residual areas7-438Processing Times9-19.1Indirect addressing9-19.2Compare instruction examples9-39.3FIFO instruction examples9-3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 7.19.6  |                                                               | 7–27 |
| 7.19.9       Extracting square root       7-24         7.19.10       Exponentiation       7-26         7.19.11       Logarithmic functions       7-30         7.19.12       Trigonometric functions floating point       7-30         7.20       Parameter assignments       7-37         7.21       Local symbol names & auxiliary markers for program tracking       7-37         7.22       System variable       7-37         7.23       Jump instructions       7-37         7.24       Module calls       7-36         7.25       End of module instruction       7-36         7.26       FIFO instructions for time-controlled processing       7-37         7.29       Program stop and program end       7-44         7.29       Program stop and program end       7-44         7.30       Backing up and loading residual areas       7-42         8       Processing Times       8-1         9       Sample Programs       9-1         9.1       Indirect addressing       9-2         9.2       Compare instruction examples       9-2         9.3       FIFO instruction examples       9-3         9.3       FIFO instruction examples       9-3         9.3 <td>7.19.7</td> <td>Calculating with floating point values</td> <td>7–28</td> | 7.19.7  | Calculating with floating point values                        | 7–28 |
| 7.19.10       Exponentiation       7-24         7.19.11       Logarithmic functions       7-30         7.19.12       Trigonometric functions floating point       7-30         7.20       Parameter assignments       7-31         7.21       Local symbol names & auxiliary markers for program tracking       7-31         7.22       System variable       7-33         7.23       Jump instructions       7-32         7.24       Module calls       7-33         7.25       End of module instruction       7-33         7.26       FIFO instructions       7-33         7.27       Block commands       7-33         7.28       Interrupt instructions for time-controlled processing       7-41         7.29       Program stop and program end       7-42         7.30       Backing up and loading residual areas       7-42         8       Processing Times       8-1         9       Sample Programs       9-1         9.1       Indirect addressing       9-2         9.2       Compare instruction examples       9-3         9.3       FIFO instruction examples       9-3         9.3       FIFO instruction examples       9-3         9.3       FIFO                                                                                    | 7.19.8  | Forming absolute value                                        | 7–29 |
| 7.19.11Logarithmic functions7-307.19.12Trigonometric functions floating point7-307.20Parameter assignments7-317.21Local symbol names & auxiliary markers for program tracking7-337.22System variable7-337.23Jump instructions7-337.24Module calls7-347.25End of module instruction7-367.26FIFO instructions7-377.27Block commands7-367.28Interrupt instructions for time-controlled processing7-477.29Program stop and program end7-477.30Backing up and loading residual areas7-478Processing Times8-19Sample Programs9-19.1Indirect addressing9-39.2Compare instruction examples9-39.3FIFO instruction examples9-39.4AppendixA-1A.1AbbreviationsA-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 7.19.9  | Extracting square root                                        | 7–29 |
| 7.19.11Logarithmic functions7-307.19.12Trigonometric functions floating point7-307.20Parameter assignments7-317.21Local symbol names & auxiliary markers for program tracking7-317.22System variable7-337.23Jump instructions7-337.24Module calls7-337.25End of module instruction7-367.26FIFO instructions7-337.27Block commands7-337.28Interrupt instructions for time-controlled processing7-417.29Program stop and program end7-427.30Backing up and loading residual areas7-428Processing Times8-19Sample Programs9-19.1Indirect addressing9-29.3FIFO instruction examples9-39.4AppendixA-1A.1AbbreviationsA-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 7.19.10 | Exponentiation                                                | 7–29 |
| 7.19.12Trigonometric functions floating point7-307.20Parameter assignments7-377.21Local symbol names & auxiliary markers for program tracking7-377.22System variable7-377.23Jump instructions7-377.24Module calls7-377.25End of module instruction7-377.26FIFO instructions7-377.27Block commands7-377.28Interrupt instructions for time-controlled processing7-477.29Program stop and program end7-477.30Backing up and loading residual areas7-478Processing Times8-19Sample Programs9-19.1Indirect addressing9-39.2Compare instruction examples9-39.3FIFO instruction examples9-39.4AppendixA-1A.1AbbreviationsA-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 7.19.11 |                                                               | 7–30 |
| 7.20Parameter assignments7-37.21Local symbol names & auxiliary markers for program tracking7-37.22System variable7-37.23Jump instructions7-37.24Module calls7-37.25End of module instruction7-37.26FIFO instructions7-37.27Block commands7-37.28Interrupt instructions for time-controlled processing7-47.29Program stop and program end7-447.30Backing up and loading residual areas7-448Processing Times8-19Sample Programs9-19.1Indirect addressing9-29.3FIFO instruction examples9-39.3FIFO instruction examples9-39.4AppendixA-1AAppendixA-1A.1AbbreviationsA-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 7.19.12 |                                                               | 7–30 |
| 7.21Local symbol names & auxiliary markers for program tracking .7-37.22System variable .7-37.23Jump instructions .7-37.24Module calls .7-37.25End of module instruction .7-37.26FIFO instructions .7-37.27Block commands .7-37.28Interrupt instructions for time-controlled processing .7-47.29Program stop and program end .7-47.30Backing up and loading residual areas .7-448Processing Times .8-19Sample Programs .9-19.1Indirect addressing .9-19.2Compare instruction examples .9-39.3FIFO instruction examples .9-39.4Appendix .A-1AAppendix .A-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 7.20    |                                                               | 7–31 |
| 7.22       System variable       7-3         7.23       Jump instructions       7-3         7.24       Module calls       7-3         7.25       End of module instruction       7-3         7.26       FIFO instructions       7-3         7.27       Block commands       7-3         7.28       Interrupt instructions for time-controlled processing       7-4         7.29       Program stop and program end       7-4         7.30       Backing up and loading residual areas       7-4         8       Processing Times       8-1         9       Sample Programs       9-1         9.1       Indirect addressing       9-1         9.2       Compare instruction examples       9-2         9.3       FIFO instruction examples       9-3         9.3       FIFO instruction examples       9-3                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 7.21    | Local symbol names & auxiliary markers for program tracking . | 7–31 |
| 7.23       Jump instructions       7–33         7.24       Module calls       7–34         7.25       End of module instruction       7–36         7.26       FIFO instructions       7–37         7.27       Block commands       7–37         7.28       Interrupt instructions for time-controlled processing       7–47         7.29       Program stop and program end       7–47         7.30       Backing up and loading residual areas       7–47         8       Processing Times       8–1         9       Sample Programs       9–1         9.1       Indirect addressing       9–1         9.2       Compare instruction examples       9–2         9.3       FIFO instruction examples       9–3         9.3       FIFO instruction examples       9–3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 7.22    |                                                               | 7–31 |
| 7.24       Module calls       7-34         7.25       End of module instruction       7-34         7.26       FIFO instructions       7-37         7.27       Block commands       7-37         7.28       Interrupt instructions for time-controlled processing       7-47         7.29       Program stop and program end       7-47         7.30       Backing up and loading residual areas       7-47         8       Processing Times       8-1         9       Sample Programs       9-1         9.1       Indirect addressing       9-1         9.2       Compare instruction examples       9-2         9.3       FIFO instruction examples       9-3         A       Appendix       A-1         A.1       Abbreviations       A-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 7.23    |                                                               | 7–32 |
| 7.25End of module instruction7-367.26FIFO instructions7-377.27Block commands7-387.28Interrupt instructions for time-controlled processing7-477.29Program stop and program end7-477.30Backing up and loading residual areas7-478Processing Times8-19Sample Programs9-19.1Indirect addressing9-19.2Compare instruction examples9-29.3FIFO instruction examples9-34AppendixA-1A.1AbbreviationsA-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |         |                                                               | 7–34 |
| 7.26FIFO instructions7-377.27Block commands7-387.28Interrupt instructions for time-controlled processing7-477.29Program stop and program end7-477.30Backing up and loading residual areas7-478Processing Times8-19Sample Programs9-19.1Indirect addressing9-19.2Compare instruction examples9-29.3FIFO instruction examples9-3AAppendixA-1A.1AbbreviationsA-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         |                                                               | 7–36 |
| 7.27Block commands7-387.28Interrupt instructions for time-controlled processing7-47.29Program stop and program end7-47.30Backing up and loading residual areas7-48Processing Times8-19Sample Programs9-19.1Indirect addressing9-19.2Compare instruction examples9-29.3FIFO instruction examples9-3AAppendixA-1A.1AbbreviationsA-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |                                                               | 7–37 |
| 7.28Interrupt instructions for time-controlled processing7-47.29Program stop and program end7-47.30Backing up and loading residual areas7-48Processing Times8-19Sample Programs9-19.1Indirect addressing9-19.2Compare instruction examples9-29.3FIFO instruction examples9-3AAppendixA-1A.1AbbreviationsA-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |                                                               | 7–38 |
| 7.29Program stop and program end7-47.30Backing up and loading residual areas7-428Processing Times8-19Sample Programs9-19.1Indirect addressing9-19.2Compare instruction examples9-29.3FIFO instruction examples9-3AAppendixA-1A.1AbbreviationsA-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |                                                               | 7-41 |
| 7.30Backing up and loading residual areas7-428Processing Times8-19Sample Programs9-19.1Indirect addressing9-19.2Compare instruction examples9-29.3FIFO instruction examples9-3AAppendixA-1A.1AbbreviationsA-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         |                                                               | 7-41 |
| 8       Processing Times       8–1         9       Sample Programs       9–1         9.1       Indirect addressing       9–2         9.2       Compare instruction examples       9–2         9.3       FIFO instruction examples       9–3         A       Appendix       A–1         A.1       Abbreviations       A–1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |                                                               | 7–42 |
| 9Sample Programs9–19.1Indirect addressing9–29.2Compare instruction examples9–29.3FIFO instruction examples9–3AAppendix9–3A.1AbbreviationsA–1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 7.00    |                                                               | 1 72 |
| 9.1Indirect addressing9–9.2Compare instruction examples9–29.3FIFO instruction examples9–2AAppendix9–2A.1AbbreviationsA–1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 8       | Processing Times                                              | 8–1  |
| 9.2       Compare instruction examples       9-2         9.3       FIFO instruction examples       9-2         A       Appendix       9-2         A.1       Abbreviations       A-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 9       | Sample Programs                                               | 9–1  |
| 9.2       Compare instruction examples       9-2         9.3       FIFO instruction examples       9-2         A       Appendix       9-2         A.1       Abbreviations       A-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 9.1     | Indirect addressing                                           | 9–1  |
| 9.3         FIFO instruction examples         9-3           A         Appendix         A-1           A.1         Abbreviations         A-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 9.2     | Compare instruction examples                                  | 9–2  |
| AAppendixA-1A.1AbbreviationsA-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 9.3     |                                                               | 9–3  |
| A.1 Abbreviations A-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |                                                               |      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Α       | Appendix                                                      | A–1  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | A.1     | Abbreviations                                                 | A–1  |
| A.2 Index A-2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | A.2     | Index                                                         | A–2  |

Notes:

# 1 Safety Instructions

Before you start working with the iPCL, we recommend that you thoroughly familiarize yourself with the contents of this manual. Keep this manual in a place where it is always accessible to all users.

### 1.1 Intended use

This manual contains information required for the proper use of this product. However, for reasons of structural clarity, the manual cannot provide exhaustive details regarding all available combinations of functional options. Similarly, it is feasible to consider every conceivable integration or operating scenario within the confines of this manual.

The Typ3 osa and PNC controls serve as

- activate feed drives, spindles and auxiliary axes of a machine tool via SERCOS interface for the purpose of guiding a processing tool along a programmed path to process a workpiece (CNC). Furthermore, a PLC is required with appropriate I/O components which – in communication with the actual CNC – controls the machine processing cycles holistically and acts as a technical safety monitor.
- program contours and the processing technology (path feedrate, spindle speed, tool change) of a workpiece.

Any other application is deemed improper use!

The products described hereunder

- have been developed, manufactured, tested and documented in compliance with the safety standards. These products pose no danger to persons or property if they are used in accordance with the handling stipulations and safety notes prescribed for their configuration, mounting, and proper operation.
- comply with the requirements of
  - the EMC Directives (89/336/EEC, 93/68/EEC and 93/44/EEC)
  - the Low-Voltage Directive (73/23/EEC)
  - the harmonized standards EN 50081-2 and EN 50082-2
  - are designed for operation in industrial environments, i.e.
  - no direct connection to public low-voltage power supply,
  - connection to the medium- or high-voltage system via a transformer.

In residential environments, in trade and commerce as well as small enterprises class A equipment may only be used if the following warning is attached:

□ This is a Class A device. In a residential area, this device may cause radio interference. In such case, the user may be required to introduce suitable countermeasures, and to bear the cost of the same.

The faultless, safe functioning of the product requires proper transport, storage, erection and installation as well as careful operation.

### 1.2 Qualified personnel

The requirements as to qualified personnel depend on the qualification profiles described by ZVEI (central association of the electrical industry) and VDMA (association of German machine and plant builders) in: Weiterbildung in der Automatisierungstechnik edited by: ZVEI and VDMA MaschinenbauVerlag Postfach 71 08 64 D-60498 Frankfurt.

This manual is intended for **project engineers and NC specialists**, who are familiar with programmable logic controllers (PLC). A special knowledge of how to configure and commission electrical equipment is also required

Programming, start and operation as well as the modification of program parameters is reserved to properly trained personnel! This personnel must be able to judge potential hazards arising from programming, program changes and in general from the mechanical, electrical, or electronic equipment.

Interventions in the hardware and software of our products, unless described otherwise in this manual, are reserved to our specialized personnel.

Tampering with the hardware or software, ignoring warning signs attached to the components, or non-compliance with the warning notes given in this manual may result in serious bodily injury or material damage.

Only electrotechnicians as recognized under IEV 826-09-01 (modified) who are familiar with the contents of this manual may install and service the products described.

Such personnel are

- those who, being well trained and experienced in their field and familiar with the relevant norms, are able to analyze the jobs being carried out and recognize any hazards which may have arisen.
- those who have acquired the same amount of expert knowledge through years of experience that would normally be acquired through formal technical training.

With regard to the foregoing, please note our comprehensive range of training courses. For current information, the web shop and online booking of seminars please visit our website http://www.bosch.de/at/didactic. Our training center will be pleased to provide you with further information, telephone: (+49) (0 60 62) 78–258.

# 1.3 Safety markings on products



Warning of dangerous electrical voltage!

DANGER! Corrosive battery acid!

Electrostatically sensitive components!

Hazardous light emissions (optical fibre cable emitters)!

Disconnect mains power before opening!

Lug for connecting PE conductor only!

Connection of shield conductor only

# 1.4 Safety instructions in this manual



#### DANGEROUS ELECTRICAL VOLTAGE

This symbol is used to warn of a **dangerous electrical voltage**. The failure to observe the instructions in this manual in whole or in part may result in **personal injury**.



#### DANGER

This symbol is used wherever insufficient or lacking compliance with instructions may result in **personal injury**.



#### CAUTION

This symbol is used wherever insufficient or lacking compliance with instructions may result in **damage to equipment or data files**.

IF This symbol is used to draw the user's attention to special circumstances.

 $\star$  This symbol is used if user activities are required.

| 1.5 | Safety instructions for the described product                                                                                                                                                                                                                                                                                                                |  |  |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|     | DANGER<br>Danger of life through inadequate EMERGENCY-STOP devices!<br>EMERGENCY-STOP devices must be active and within reach in all<br>system modes. Releasing an EMERGENCY-STOP device must not<br>result in an uncontrolled restart of the system!<br>First check the EMERGENCY-STOP circuit, then switch the system<br>on!                               |  |  |
|     | DANGER<br>Risk of personal injury and equipment damage!<br>Always subject new programmes to initial tests while inhibiting axis<br>movements. For this purpose, as a function of the AUTOMATIC<br>mode, the controller provides the option to block axis movements or<br>auxiliary functions by means of special softkey commands.                           |  |  |
|     | DANGER<br>Incorrect or undesired control unit response!<br>Bosch accepts no liability for damage resulting from the execution<br>of an NC program, an individual NC block or the manual movement<br>of axes!<br>Furthermore, Bosch accepts no liability for consequential damage<br>which could have been avoided by programming the PLC appropri-<br>ately! |  |  |
|     | DANGER<br>Retrofits or modifications may adversely affect the safety of the<br>products described!<br>The consequences may include severe injury, damage to equipment,<br>or environmental hazards. Possible retrofits or modifications to the<br>system using third-party equipment therefore have to be approved<br>by Bosch.                              |  |  |
|     | DANGEROUS ELECTRICAL VOLTAGE<br>Unless described otherwise, maintenance works must be performed<br>on inactive systems! The system must be protected against unau-<br>thorized or accidental reclosing.                                                                                                                                                      |  |  |
|     | Measuring or test activities on the live system are reserved to quali-<br>fied electrical personnel!                                                                                                                                                                                                                                                         |  |  |



#### DANGER

Tool or axis movements! Feed and spindle motors generate very powerful mechanical forces and can accelerate very quickly due to their high dynamics.

- Always stay outside the danger area of an active machine tool!
- Never deactivate safety-relevant functions!
- Report any malfunction of the unit to your servicing and repairs department immediately!

#### CAUTION

CAUTION

Use only spare parts approved by Bosch!



# Danger to the module! All ESD protection measures must be observed when using the module! Prevent electrostatic discharges!

The following protective measures must be observed for modules and components sensitive to electrostatic discharge (ESD)!

- Personnel responsible for storage, transport, and handling must have training in ESD protection.
- ESD-sensitive components must be stored and transported in the prescribed protective packaging.
- ESD-sensitive components may only be handled at special ESD-workplaces.
- Personnel, working surfaces, as well as all equipment and tools which may come into contact with ESD-sensitive components must have the same potential (e.g. by grounding).
- Wear an approved grounding bracelet. The grounding bracelet must be connected with the working surface through a cable with an integrated 1 MΩ resistor.
- ESD-sensitive components may by no means come into contact with chargeable objects, including most plastic materials.
- When ESD-sensitive components are installed in or removed from equipment, the equipment must be de-energized.

# 1.6 Documentation, software release and trademarks

#### Documentation

This manual provides details of the programming and operation of the iPCL. Not included are general procedures for project management and installation of controllers and their associated hardware.

| Overview of available documentation                                             | Part no.     |              |  |
|---------------------------------------------------------------------------------|--------------|--------------|--|
|                                                                                 | German       | English      |  |
| Typ3 osa – Interface conditions<br>for project engineering and maintenance      | 1070 073 704 | 1070 073 736 |  |
| Typ3 osa – Software installation                                                | 1070 073 796 | 1070 073 797 |  |
| Decription of functions                                                         | 1070 073 870 | _            |  |
| MACODA<br>Operation and configuration of the machine<br>parameters              | 1070 073 705 | 1070 073 742 |  |
| Operating instructions<br>Standard operator interface                           | 1070 073 726 | 1070 073 739 |  |
| Operating instructions – Diagnostics Tools                                      | 1070 073 779 | 1070 073 780 |  |
| Error Messages                                                                  | 1070 073 798 | 1070 073 799 |  |
| PLC project planning manual,<br>Software interfaces of the integrated PLC       | 1070 073 728 | 1070 073 741 |  |
| iPCL system description and<br>programming manual                               | 1070 073 874 | 1070 073 875 |  |
| ICL700 system description,<br>Program structure of the integrated PLC<br>ICL700 | 1070 073 706 | 1070 073 737 |  |
| DIN programming manual<br>for programming to DIN 66025                          | 1070 073 725 | 1070 073 738 |  |
| CPL programming manual                                                          | 1070 073 727 | 1070 073 740 |  |
| CPL-Debugger Operating instructions                                             | 1070 073 872 | _            |  |
| Tool Management – Parameterization                                              | 1070 073 782 | 1070 073 793 |  |
| Software PLC<br>Development environment for Windows NT                          | 1070 073 783 | 1070 073 792 |  |
| Measuring cycles for<br>touch-trigger switching probes                          | 1070 073 788 | 1070 073 789 |  |
| Universal Milling Cycles                                                        | _            | 1070 073 795 |  |

In this manual the floppy disk drive always uses drive letter A:, and the hard disk drive always uses drive letter C:.

Special keys or key combinations are shown enclosed in pointed brackets:

- Named keys: e.g., <Enter>, <PgUp>, <Del>
- Key combinations (pressed simultaneously): e.g., <Ctrl> + <PgUp>

#### Release

#### IF The descriptive information contained in this manual applies to: Software version: V7.x

The current release number of the individual software modules can be viewed by selecting the 'Control-Diagnostics' softkey in the 'Diagnostics' group operating mode.

The software version of Windows95 or WindowsNT may be displayed as follows:

1. Click the right mouse button on the My Computer icon on your desktop.

2. Select Properties.

#### Trademarks

All trademarks of software installed on Bosch products upon delivery are the property of the respective manufacturer.

Upon delivery, all installed software is copyright-protected. The software may only be reproduced with the approval of Bosch or in accordance with the license agreement of the respective manufacturer.

 $\text{MS-DOS}^{\textcircled{\text{\tiny (8)}}}$  and  $\text{Windows}^{\,\scriptsize{\text{\tiny (M)}}}$  are registered trademarks of Microsoft Corporation.

PROFIBUS® is a registered trademark of the PROFIBUS Nutzerorganisation e.V. (user organization).

SERCOS interface<sup>™</sup> is a registered trademark of the SERCOS interface Joint VDW/ZVEI Working Committee.

# 2 System Overview

### 2.1 Functionality

iPCL is a software PLC integrated into the NC control. Without additional hardware iPCL is integrated into:

- the PNC plug-in card
- the type 3 osa component group osa master P-L and osa master P-XL.

Thus a secure functionality is assured independently of Windows.

I/O's are connected via PROFIBUS-DP, enabling RM65M-16DP,  $\,$  B~IO-modules to be used, for example.

For the operation and programming of iPCL, the following configuration software is required:

- WinSPS: Creation of the PLC application program with functional extensions for communication between PLC and NC (APS modules)
- WinDP: Configuration of the PROFIBUS-DP

Communications with the WinSPS, WinDP and other programs are handled by the TCP/IP standard protocol with the use of the BUEP (Bosch transfer protocol) command language.

For the creation of the PLC program or individual program modules in the programming language C, the C compiler and linker are also required.

**□** For additional essentials related to iPCL and to operating decentralized peripherals via the PROFIBUS-DP, refer to the Online Help in WinSPS and WinDP.

## 2.2 Hardware platforms

iPCL is integrated in:

- the PNC plug-in card
- the Typ3 osa component group osa master P-L and osa master P-XL.

#### iPCL in PNC (e.g. in the operating terminal BT205)



#### iPCL in the osa master P-L/XL (Typ3 osa)



#### 2.3 **iPCL** extensions

-

| The maximum I/O area and the PLC user memory (MACODA |
|------------------------------------------------------|
| parameter 2060 00210) are determined by licence:     |

| Туре                              | Peripherals                                     | User memory                                                             |
|-----------------------------------|-------------------------------------------------|-------------------------------------------------------------------------|
| iPCL_1 (PNC)                      | 16 kb for inputs<br>16 kb for outputs           | 32 kbytes                                                               |
| iPCL_2 (PNC)                      | 256 kb for inputs<br>256 kb for outputs         | 128 kbytes                                                              |
| iPCL_3 (PNC)                      | 8 kb for inputs<br>8 kb for outputs             | 512 kbytes                                                              |
| iPCL_4<br>(osa master P-<br>L/XL) | -256 bytes for inputs<br>-256 bytes for outputs | Default: 200 kb depending<br>on free memory in the osa<br>master P-L/XL |

Because the data field and data buffer are included in every hardware expansion level, they do not reduce the size of the user memory! Just like the program and organization modules, the data modules are stored in the PLC user memory.

#### Additional options

OPC server functions are available. It enables MADAP STUDIO to be used together with the PNC.

# 2.4 Data backup

PNC

iPCL uses PNC's own memory (SDRAM) and the hard disk of the base unit into which the PNC is plugged.

Optimum functional security of the iPCL in the PNC is attained by using a UPS (uninterruptible power supply), which bridges a potential power loss to allow essential PLC and NC data to be backed up to hard disk and leads to a delayed shut down of the Windows NT operating system.

| SDRAM                                                                                                    |                                         |                                                                                                                                                                                                                 |                                                                                                                                                            |                                                  |
|----------------------------------------------------------------------------------------------------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|
| iPCL memory<br>• PLC program<br>(SoftSPS.bin)<br>• Fixationlist<br>(Fix.bin)<br>• Status<br>(Status.bin) | Data comparis<br>for every<br>amendment | Son<br>Memory for<br>RAM filing system<br>• PLC program<br>(SoftSPS.bin)<br>• Fixation list<br>(Fix.bin)<br>• Status<br>(Status.bin)<br>• Parts program<br>• Machine data<br>Backup<br>on shutdown<br>(as file) | Memory for program<br>execution<br>• residual data<br>and areas and<br>FIFO's<br>Memory for cyclic<br>backup<br>• residual data<br>and areas and<br>FIFO's | Backup by iPCL<br>on shutdown                    |
| Base device (e.g. P(<br>Hard disk<br>Mount directory                                                     | operating pane                          | RAM filing s<br>file:<br>• PLC pro                                                                                                                                                                              | ystem backed up in a<br>ogram (SoftSPS.bin)<br>I list (Fix.bin)                                                                                            | Backup on<br>shutdown<br>after iPCL has<br>ended |

#### osa master P-L/XL (SNCI4)

iPCL uses various memory areas of the component group osa master P-L/XL:

- SDRAM (dynamic mamory) for PLC program and data in use.
- SRAM (static memory) for PLC program and data for switched off control and cyclic backups.
- FEPROM for additional back up of the PLC program.



Notes:

# 3 Configuration

# 3.1 Connecting to the system

### Registering iPCL via MACODA

iPCL has to be registered in the MACODA parameter 2060 00200. Apart from that further parameters can be changed:

- 2060 00200: Selection of the PCL.
- Must be set to iPCL (= 4).
  2060 00210: Maximum size of the user program. For the PNC the size may be limited by licence, (for detailed information, refer to Section 2.3)
  2060 00211: Max PLC computing time in %. (see Section 8).

#### Interfacing with Peripherals

The interfacing with peripherals is viy the serial filed bus system **PROFI-BUS-DP** via the PROFIBUS-DP Busmaster interface:

- for base devices with PNC: on the "PNC-PCI card"
- for the Typ3 osa hardware: on the component group "osa dc I/O"

The maximum I/O area is determined by licence.

Reference list:

The bus master monitors the existence of slaves and transfers this data to the iPCL.

Error functions:

The error functions are dependent on the bus system used. The PROFI-BUS-DP field bus features a comprehensive diagnostic system whose messages are made available by the iPCL bus master.

#### System clock management

The system timing, which can be processed in the PLC program via the system area, is generated by the clock source onboard the PC.

# BOSCH

# 3.2 Startup of the iPCL

There follows the initialization and the start-up diagram for the iPCL. This procedure is the same for all hardware platforms.



# 3.2.1 Initialization of the iPCL

|                              | In the initiali                                                                                                                                                                               | zation phase the iPCL operating system starts up.                                                                                                                    |
|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Initializing special markers | The special markers SM21.0 to SM31.7 (see below: "Exceptions") are pre-<br>initialized during "New start" and "Restart". They are subsequently modified<br>in accordance with their function. |                                                                                                                                                                      |
| Initialization values        |                                                                                                                                                                                               |                                                                                                                                                                      |
|                              | SM 26                                                                                                                                                                                         | = FFFF <sub>H</sub>                                                                                                                                                  |
|                              | SM 31.1                                                                                                                                                                                       | = 1                                                                                                                                                                  |
|                              | All others                                                                                                                                                                                    | = 0                                                                                                                                                                  |
| Exceptions for initial start |                                                                                                                                                                                               |                                                                                                                                                                      |
| ·                            | SM 20.0                                                                                                                                                                                       | Reset impulse for new start and restart<br>Is set to 1 for iPCL new start and restart. Marker is deleted if<br>OM1 has been processed at least once.                 |
|                              | SM 20.1                                                                                                                                                                                       | Buffer fault<br>Is set if the buffering of residual data was not correct.                                                                                            |
|                              | SM 20.2                                                                                                                                                                                       | Flashing marker<br>Flashes at 2 Hz after iPCL startup                                                                                                                |
|                              | SM 20.3                                                                                                                                                                                       | Block outputs<br>Is set according to the requests for output blocking. Always up-<br>dated during I/O state.                                                         |
|                              | SM 20.4                                                                                                                                                                                       | Fixation markers<br>Is set in accordance with the fixation request. Always updated<br>during I/O state.                                                              |
|                              | SM 20.5                                                                                                                                                                                       | Data backup error<br>Is set if the buffering of residual data was not correct.                                                                                       |
|                              | SM 20.6                                                                                                                                                                                       | Non-residual cold start<br>Is set when the cold start has occurred and all residual areas<br>were deleted.                                                           |
|                              | SM 20.7                                                                                                                                                                                       | Reset impulse for new start and program load<br>Is set to 1 for iPCL new start and after program load. Marker is<br>deleted if OM1 has been processed at least once. |

# 3.2.2 Startup diagram

#### Startup conditions

After initialization the actual iPCL Startup begins.

During startup an attempt is made by the PLC program to load various files and data. Here different settings and potential events during the run up are taken into account.

- Switch setting S1
- residual or non-residual startup characteristics (see page 3–5)
- after startup stop (for new start, see page 3–7)
- after processing stop (for restart, see page 3-8)

#### Switch setting S1

The loading of the PLC program and the data occurs with the pre-setting of the rotary switch S1 on the osa master P-L/XL or startup mode in "PNC control" for the PNC.

| The following switch | settings | are possible: |
|----------------------|----------|---------------|
|----------------------|----------|---------------|

| Switchsetting<br>or startup<br>mode | Characteristics (PNC / osa master P-L/XL)                                                                                                     |
|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 0                                   | Startup from the RAM filing system. The PLC program and residual data are loaded.<br>The PLC program is starting.                             |
| 1                                   | As 0, but the PLC program will <b>not</b> start.                                                                                              |
| 2                                   | The PLC program backed up on hard disk (PNC) or in the user FEPROM (usr-fep) and residual data are being loaded. The PLC program is starting. |
| 4, 5                                | As 0.                                                                                                                                         |
| 6                                   | As 2.<br>Additionally the RAM filing system is being newly created.<br>The fixation list is being deleted.                                    |
| 7                                   | As 0.<br>Simultaneously the backup of the RAM filing system is de-<br>leted.                                                                  |

#### Startup characteristics

The startup characteristics are dependent on whether events such as "stop" or "new start" have already occurred that cause a certain startup procedure:

- After a startup stop or an **initial** "Power ON" a "**New start**" is initiated for the iPCL.
- After a processing stop a "Restart" is initiated (see page 3-8).

#### **Both startup types can occur non-residual or residual.**

For each startup type there is an organization module available, which if it has been programmed in the PLC program, will run depending on the stop condition that has occurred:

**OM5**: New start OM, non-residual or partially residual **OM7**: Restart OM, non-residual or partially residual

If the startup OMs are not programmed in the PLC program, then the corresponding startup proceeds without OM processing. In all startup types the factors from the OM2 are used or if they are not available, then default values are used.

# If iPCL starts up with default settings, then it is always a "non-residual startup".

The data affecting the system area (times for time-controlled OMs, residual limits) can then be modified in the respective startup OM.

For iPCL there is no full-residual restart but only a partial-residual startup. The areas of the markers, times and counters defined as residual are kept. A full-residual startup, where the PLC program continues at the exact place in the program where it was stopped, is not possible because also the NC, which is connected to the iPCL, does not recognize a residual startup.

Consequently in the following text the expression "residual" in association with the iPCL is always to be interpreted as "partial-residual"!

#### Startup sequence

The iPCL startup sequence proceeds as residual or non-residual.

- 1. Load inputs
- Overlay fixation: it already works for direct access from the startup OM. However, the output to the peripherals does not occur directly, and the output image is not updated.
- 3. Stop command query:
  - if stop then a system stop is carried out
  - if no stop then the new start OM(OM5) is processed. This OM permits the use of all PLC instructions (also applies to restart OM(OM7)), e.g., to set outputs, to initialize or start timer or counter values, to manipulate values in the system area (to influence initialization values), or to modify residual limits.
- 4. Final initialization: Once the startup OM has been processed, the final initialization is executed, utilizing the values from the system table and system area. Values such as time monitoring, OM time values, etc., are adopted or updated.Provided the respective setting has been made in the OM2, the specified data module is copied into the data buffer.
- 5. Execute complete I/O state



- 6. Start program processing on the OM1.
- 7. Start timeframe processing for the times and release time OM processing.
- If for an osa master P-L/XL card the PLC program is switched again to STOP after the startup of the controller (also applies to loading with control STOP), the READY signal drops and only returns if the rotary switch is briefly turned to a setting > 7. This behaviour is determined by the hardware and cannot be influenced by software. When a program or module is reloaded without control stop, the READY signal stays on.

In the PNC the READY signal returns automatically after the restart of the PLC program.

#### Cold start flag

When the cold start flag is set, this forces a non-residual startup. This flag can be manipulated by either operating system or PG.

- Operating system: When the iPCL is switched on the PLC program is loaded from the softsps.bin file into memory. If an error occurs in the course of this process, the cold start flag will be set.
- Programming unit (WinSPS): The cold start flag is set when 'loading entire program with reset of residual operands'.

# 3.2.3 Startup conditions

| Startup without error     | <ul> <li>A startup without error occurs when, subsequent to error-free program processing, the controller (NC and iPCL) is cycled OFF and ON again:</li> <li>The PLC program can be loaded again error-free into the PLC user memory.</li> <li>The residual areas are error-free</li> <li>The selected new start OM(OM5) is processed.</li> <li>During creation by WinSPS, the fixation lists are immediately backed up in the filing system. These fixation lists are loaded when the controller is started up.</li> <li>The cold start flag is not set.</li> <li>The startup is executed, and cyclical program processing is started.</li> <li>After PLC has been put into STOP state by the programming unit, it does not remain in this state when PLC is restarted.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           | If an error occurs at this juncture, the iPCL will enter Process-STOP, and will no longer enter Startup-STOP.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Startup with startup STOP | In the event that during the startup subsequent to power ON a "hardware fault" or "STOP request" occurs, the iPCL will remain in <b>Startup-STOP</b> mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                           | <ul> <li>Reasons for a stop request can be:</li> <li>No PLC user program in the directory (PNC) or in the filing system (osa master P-L/XL).</li> <li>Startup mode (PNC) or osa master P-L/XL rotary switch set S1= 1 (corresponds to stop)</li> <li>Severe faults occurred during controller run-up, e.g. faults originating in the installation of peripheral drivers, initialization of PLC operating system, or communication channel setup.<br/>These faults produce the message "System stop" and do not permit a retriggering, i.e. the controller has to be resarted (reset).<br/>Faults that produce a controller stop are reported to the NC and are displayed on the operating panel in the INFO dialogue of the standard BOF.</li> <li>Incorrect or non-existent fixation lists file in the PNC root directory. The iPCL stays in startup stop mode until a fixation list is loaded. Loading an "empty" list deletes the fixation identifier.</li> <li>Flag for residual test has been set in OM2, and residual error has been detected.</li> <li>Flag for cyclical backup set in the OM2 and operand backup to the static RAM (osa master P-L/XL) or SDRAM (PNC) is not possible.</li> <li>Startup stop mode is left as soon as the fault has been fixed. By command from the programming unit (WinSPS) or in the PNC control, startup stop mode can be left by switching to RUN.</li> </ul> |

□ After startup stop there always follows a "New start".



#### Startup with processing STOP

Once the program processing has begun with the OM1, and an error or a STOP request occurs, this will cause a **Process-STOP** condition. This stop condition is left as soon as the fault has been fixed or if the reason for the stop has disappeared and the switch in the iPCL control panel was set to RUN.

The stop state can also be left by command from the programming unit (WinSPS).

#### Non-residual new start or restart

The **non-residual** startup mode is used in the following cases:

- The system area flag is set in OM2.
- Subsequent to a memory error, as this precludes a residual startup.
- A non-residual startup was requested from the PG (WinSPS) (only possible when loading).

To describe the process in detail:

- All image areas (residual and non-residual) are deleted.
- Fixation is deleted upon new start, and retained upon restart.
- Stored interrupts are deleted.
- Application stack is reset.
- Outputs are enabled.
- Inputs are loaded.

#### Residual new start or restart

The **residual** startup mode is used in the following cases:

- No memory error has occurred.
- and no non-residual startup was requested by PG (WinSPS) or via the OM2.

To describe the process in detail:

- Non-residual areas are deleted.
- Timer values are transferred.
- Outputs are enabled.
- Inputs are loaded.
- If an error occurs while loading the residual data, an error message is generated and the PLC program does not start automatically. The residual data area is re-initialized. The PLC program can be started either with a renewed run up of the controller or with the PG (WinSPS).

#### 3.3 Data backup and residual characteristics of the iPCL

Data backup is essential so that relevant PLC data are available for continued processing even after a power failure when the RAM filing system was newly created or in an error situation.

Data

The following data and files are associated with a current project:

- Residual areas:
  - Identified data modules
  - Data fields and data buffers
  - Markers
  - Times
  - Counters
  - FIFOs
- Files:
  - PLC program
  - Fixation lists
  - Status

#### 3.3.1 Data backup depending on hardware platform

PNC

PNC has a dynamic RAM (SDRAM) that does **not** allow storage of data when the controller is switched off.

The PLC application program is in the filing system, the data in the RAM. When the PNC is run up the data and the PLC program are automatically loaded from the local hard disk or from an additionally mounted directory of a hard disk (e.g. from a network computer) into the PLC user memory.

During program execution the user can, under program control, store certain residual data (cyclical) in a reserved SDRAM area, but the data will be lost if the controller is switched off.



□ During normal operations the user has available the operating functions, loading and storage of the PLC program and possibly backup of the PLC project in the usr-fep directory. Cyclical backups are controlled in the OM2 or via program.

Power failure:

The PNC card is in a PC that must be attached to an "uninterruptible power supply" (UPS). The UPS ensures that in case of a power failure there is sufficient time for an orderly shutdown of iPCL and the Windows 95 or NT operating system. The essential backup of residual data, the PLC program, status and fixation list can all take place.

On the next startup PLC will load the entire backup data: the softsps.bin file, with respect to the PLC program, some other files and additional residual data that were backed up previously.

IF A backup of data to hard disk is not possible if Windows goes down but iPCL continues to run. The result is a loss of data as a re-boot is necessary.

#### osa master P-L/XL

The "static RAM" (SRAM) of the osa master P-L/XL can save the state and values of residual data, areas, fixations, the PLC program, etc. even if the controller is **switched off**.

During operations the PLC application program is a file in the filing system of the Typ3 osa. From there it is loaded into the PLC application memory when the iPCL is run up.

PLC user data are loaded from the static RAM of the osa master P-L/XL into the PLC application memory.



Certain residual data designated by the user are saved under program control in a special RAM area (SRAM). After the controller is switched off these data and the filing system remain in tact. On the next run up these cyclically saved data and the PLC program are available.

Additionally the PLC program can be saved in the FEPROM (usr-fep), so that in case of a fault or if required the PLC can be loaded with the PLC program saved there.

□ During normal operations the user has available the operating functions, loading and storage of the PLC program and possibly backup of the PLC project in the usr-fep directory. Cyclical backups are controlled in the OM2 or via program.

Power failure: In case of a power failure all relevant data from the last cyclical backup, the PLC program, fixation lists, etc. are in the SRAM. On the next run up PLC loads the PLC program saved in the SRAM and also takes into account the residual data from cyclical backups in the SRAM.

Optimal functional data security for iPCL is attained with the help of the static memory on the **osa master P-L/XL**. Every amendment is written to static memory, the contents of which are maintained even when the controller is switched off.

Selection of the residual data for cyclical backup

One can specify **which** residual data are to be backed up cyclically to the SRAM Typ3 osa or SDRAM in the PNC.

 The cyclical backup of residual areas is carried out during each I/O state. The establishment that data are to be backed up cyclically into static RAM or the osa master P-L/XL or RDRAM of the PNC occurs via entries in the OM2 (see Section 3.3.2 Establishment of the residual areas in the OM2). At program end all residual data specified in the OM2 and identified residual areas for M / T / Z / DP / DF are defined.

**Note osa master P-L/XL**: Because the process of writing to static RAM is much slower than that of writing to dynamic RAM, and thus causes the PLC cycle to be extended, the residual areas to be selected must be kept as small as possible.

• The cyclical backup procedure may be replaced by PLC instructions that perform the backup of the specified residual areas **upon request** (refer to Section 7.30 Backing up/loading residual areas): in the PLC program backup routines can be defined and executed at specific coordination points. This allows defined data to be backed up at specific times. For the backup of residual areas and of the modules designated as residual DM to the SRAM of the osa master P-L/XL or the PNC SDRAM the following measures are required:

The residual identification E for the maximum 128 data modules must be specified in the symbol file (For example: DM1,E DM\_K01).The residual limit definitions must also be declared in this case because, when copying from static into dynamic RAM, these areas must be known already during the startup sequence. The user disables the definition "Cyclical backup".

## 3.3.2 Defining residual areas in the OM2

;DW 2: Initialization flag (entries permitted) ;-Entry 0 = D 0 N 0 T test or execute function ; Entry 1 = Verify and/or execute function ; DEFW W 2#000000100000100 \*\*\*\*\*\*|\*\*\*\*\*||\* \*: not used ; +----- Check nominal cycle time ; +----- Residual start if possible ; +---- Copy data module into data buffer ; ;DW 3: System settings (entries permitted) ;-----Entry 0 = D 0 N 0 T test or execute function ; Entry 1 = Verify and/or execute function ; ; DEFW W 2#000000001000000 \* \* \* \* \* \* \* \* | | | | | | | \*: not used ; ||||||+---- Markers  $\setminus$  residual areas for ; \ cyclical Backup to the
 \static RAM, as per
 /per defined residual |||||+---- Times ; ||||+----- Counters ; |||+----- Data field ; ||+----- Data buffer / limits |+----- Data modules / ; ; 

```
;DW 7: Number of first residual time (entries permitted)
;------
   Entries from 0 to 256 are possible
;
    128 = Residual for timer loops T128 through T255
;
   256 = No residual
;
DEFW W 128
;DW 8: Number of first residual counter (entries permitted)
Entries from 0 to 256 are possible
;
   128 = Residual for counters Z128 to Z255
;
;
  256 = No residual
DEFW W 128
;DW 9: Number of first residual marker (entries permitted)
;-----
   Entries from 0 to 8192 are possible
;
   128 = Residual from marker byte M128/marker bit M128.0; the residual
;
        definition of residual limit via byte addresses
;
  8192= No residual
;
DEFW W 4096
;DW 10: First residual address in data buffer (entries permitted)
;------
   Entries from 0 to 512 are possible
;
    256 = Residual from data buffer byte DP256
;
   512 = No residual
;
DEFW W 256
;DW 33: First residual address in data field for backup to;
                                                       static
RAM (entries permitted)
:--
  Entries of 0 and 32768 possible
;
   16384 = Residual from data field byte DF16384 in static RAM
;
   32768 = No residual in static RAM
;
    Limit applies only to backup into static RAM; this area
;
   takes precedence over the data field, the remainder of which is com-
;
pletely
    backed up to hard disk for residual storage;
;
```

DEFW W 16384

# 3.3.3 Residual characteristics depending on hardware platform

| PNC with UPS                                                                                                                                                                        | osa master P-L/XL                                                                                                                                                                                                                                                                                                |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Backup of residual data is essential when powering off and on shutdown.                                                                                                             | Backup of residual data into static RAM is required under<br>program control for power off.<br>I.e. power off immediately interrupts program processing<br>and means that the data and residual conditions produced<br>in <b>this</b> cycle cannot be backed up any more.                                        |
| All residual areas/ranges can be backed up, provided they<br>have been defined as residual. In this context it is important<br>that the backed-up data originate from an PLC cycle. | The entire program management, i.e. which data are to be<br>saved under what preconditions, must be handled by the<br>programmer.                                                                                                                                                                                |
| The PLC cycle time is not affected.                                                                                                                                                 | Because the process of writing to static RAM is consider-<br>ably slower than that of writing to dynamic RAM, the PLC<br>cycle is extended. Accordingly, the residual areas must be<br>defined as small as possible.                                                                                             |
| Conclusion:<br>With a PC with UPS data backup can be assured in case of<br>a power failure.                                                                                         | Conclusion:Absolute data security cannot be ensured des-<br>pite a cyclical and request-specific data backup procedure.<br>Independent of the position in the program where proces-<br>sing is currently taking place, a power failure will cause an<br>instant system stop without the backup of residual data. |

Summary of residual characteristics under different hardware platforms

#### 3.3.4 Residual operation

The decision of residual/non-residual operation takes place in the OM2 /DW2, Bit2: "Residual if possible".

In **residual operation**, the statuses of the designated residual operands are retained after a STOP/RUN and shutdown operating mode change.

Without special arrangements in the OM2 or the system area this means for the backup of residual data in the static RAM (osa master P-L/XL) or in the directory on the local hard disk (PNC):

- The upper half of the marker range M4096 through M8191 is residual.
- The upper half of the counters Z128 through Z255 is residual.
- The upper half of the timers T128 through T255 is residual.
- The upper half of the data fields DF16384 through DF32767 is always residual.
- Data modules marked with residual ID are always residual.

The user can shift the so-called "residual limits" as desired. To this end, both OM2 and system area provide appropriate measures.

### 3.3.5 Non-residual operation

The decision of residual/non-residual operation takes place in the OM2 /DW2, Bit2: "Residual start if possible".

In **non-residual operation**, a STOP/RUN operating mode change or Power-Off/On cycle will be followed by clearing all of the following:

- All markers
- All timers
- All counters

This occurs even before processing any startup OMs.

The entire data field, DF0 through DF32767, is always residual, regardless of the position of the residual switch.

- IF For the backup of a data field in static RAM (osa master P-L/XL) or in the mounted directory of a hard disk (PNC) the defined residual limit (default OM2 or system area) applies.
- IF For the backup of data modules into static RAM (osa master P-L/XL) or into the mounted directory of a hard disk (PNC) only those DBs are taken into account that are marked with the residual ID (E) in the symbol file.

# 3.3.6 Buffer failure, data backup fault

#### Buffer failure

The special marker SM20.1 buffer failure indicates a backup fault in the saving of residual data into static RAM of the osa master P-L/XL hardware or into the directory of the local hard disk (PNC).

The marker is set in the following cases:

- If during the run up of the iPCL it is recognised that no correct backup of residual data into static RAM of the osa master P-L/XL hardware or into the directory of a hard disk (PNC) was possible either during program processing or at shutdown of the last control cycle. The special marker is set while processing a startup OM and is reset once the PLC startup has concluded.
- During program loading or post-loading, the maximum permitted number of DBs with residual ID was exceeded. The special marker remains set during program processing, and is reset while loading, provided that the maximum permitted number of DBs with residual ID is maintained.
- The cyclical backup of residual data in the I/O state was not correctly executed, the maximum permitted number of DBs with residual ID was exceeded subsequent to online modifications. The special marker remains set during program processing.
- If the special marker SM20.1 is set then the backup of all residual operands is declined both cyclically and via PLC command into the static RAM of the osa master P-L/XL hardware or into the directory of the local hard disk (PNC) but the iPCL continues to RUN. The interpretation of the SM20.1 and/or of system area word S116 permits error handling.

#### Data backup error

The special marker SM20.5 (data backup error) is set when, at the time of shutdown, the backup of residual data to the hard disk was faulty. The special marker is set during the processing of the startup OM5 power-on and is reset prior to the PLC startup OM1.

# 4 **Peripheral Operation**

The connection to the periphery is always via the PROFIBUS-DP. The PLC I/O data are transferred in I/O state or via a command to the image of the field bus master. The configured I/O modules (slaves) are serviced from there.



PROFIBUS-DP: Editor I/O

The bus master creates diagnostic tables on the basis of the I/O configuration list. The error messages and error diagnostic functions generated in this manner depend on the bus system being used, and must be evaluated with the aid of the bus-specific software tools.

#### 4.1 Data exchange machine <---> PLC

The data exchange both to the machine (PROFIBUS-DP) and the NC (bit interface) is as follows:

In the PNC:

- The machine and NC inputs (bit interface) are read at the start of the PLC process.
- The machine and NC outputs (bit interface) are given out at the end of the PLC process.

In the osa master P-L/XL:

 As determined by the DCIO, for the osa master P-L/XL both the machine inputs and the machine outputs (PROFIBUS-DP) are replaced at the start of the PLC process.

**IF** The consistency requirements of the slaves are maintained.

#### 4.2 **PROFIBUS-DP**

| Configuration     | The I/O configuration for the PROFIBUS-DP is accomplished with the aid of the <b>WinDP</b> Configuration & Diagnostic Tool.                                                                                                                                                                                      |  |  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Data exchange     | The data exchange between bus master image and peripheral devices is li-<br>mited to those slaves that have been configured.                                                                                                                                                                                     |  |  |
| Data consistency  | Data consistency is maintained only for those bus stations that have been<br>appropriately configured. The data width depends on the default values<br>taken from the device specification files.                                                                                                                |  |  |
| Peripheral errors | The PROFIBUS-DP field bus features a comprehensive diagnostic system<br>whose messages are made available to the PLC by the bus master. The<br>WinDP software also incorporates the corresponding diagnostic sys-<br>tem.When peripheral errors have been remedied, the PROFIBUS-DP re-<br>starts automatically. |  |  |
| Properties        | <ul> <li>General:</li> <li>Max. 124 slaves</li> <li>Max. 244 bytes each inputs and outputs per slave<br/>(max. 122 bytes consistent inputs or outputs)</li> <li>PROFIBUS-DP baud rates can be set to between 9.6 Kbits/s. and 12 Mbits/s.</li> </ul>                                                             |  |  |
|                   | <ul><li>Only PNC:</li><li>PROFIBUS-DP V1</li><li>Max. of 8Kbytes each inputs and outputs</li></ul>                                                                                                                                                                                                               |  |  |
|                   | <ul> <li>Only osa master P-L/XL:</li> <li>PROFIBUS-DP protocol after EN50170</li> <li>Max. of 256 bytes each inputs and outputs</li> </ul>                                                                                                                                                                       |  |  |

# 5 **Programming Basics**

Programmable memory controllers (iPCL) process a program whose code describes the controller task. This is accomplished with the use of special programming languages that can be represented and printed out in various modes.

### 5.1 Programming

#### Instruction List (IL):

The IL comprises a text-based programming language in which the controller tasks are written in assembler notation.

Structure of controller instructions:

| Controller in:  | Line comment      |                |                         |                       |
|-----------------|-------------------|----------------|-------------------------|-----------------------|
| Operations part | Operand attribute | Source operand | Destinatio<br>n operand |                       |
| OPP             | OPA               | S-OPD          | , D-OPD                 | ; Command description |

#### Examples

|   | I0.0   |                        |
|---|--------|------------------------|
| W | -Name  | , 0                    |
| В | 00     | , B                    |
| D | С      | , M12                  |
| W | 1234   | , D                    |
|   | B<br>D | W -Name<br>B OO<br>D C |

| Ladder Diagram (LD)             | When using the LD representation method, the controller tasks are de-<br>scribed by means of standard circuit diagram symbols.                                                                                                                                                                                                 |
|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function Block Diagram (FBD)    | With the programming language FBD logical connections are described using graphic symbols.                                                                                                                                                                                                                                     |
| Sequential Function Chart (SFC) | The SFC represents a graphical programming interface, which is used to de-<br>scribe the sequentially processed machine tasks in the form of a cascade<br>sequence. Before it can be loaded into the PLC, this representation is then<br>translated into the executable IL programming language.                               |
| Structured Text (ST):           | Structured text programming uses a text-based programming language in accordance with IEC 611313. Structured text is a high-level language which is easy to learn, and which facilitates compact formulation of programming tasks. Examples of its strong suits are the implementation of complex testing or regulating tasks. |

#### 5.2 **Program Structure**

In order to make PLC programs comprehensible and easy to read, structured programming is used in the PLC. Programs are divided into functionally associated program sections. To achieve structural clarity, various types of program modules are available, each handling specific tasks. Program processing can be cyclical, time or event driven.

An exemplary program structure is shown in section 5.6.4.

#### 5.3 Module Types

The controller utilizes the following module types:

- Organization modules (OM)
- Program modules
- Data modules
- **APS** modules

All modules are activated by being invoked by the PLC program. This can occur unconditionally or contingent upon a condition. A condition may be the result of a logical or compare function or an arithmetic operation.

#### 5.3.1 Organization modules (OM)

The organization modules perform all administrative or management functions for the controller program. Although they are programmed in the same manner as the program modules, only the system program invokes organization modules. All organization modules make use of the full instruction set of the PLC. There is no limitation to module size.

Each organization module is processed only subsequent to a defined condition; it cannot be called in the course of program processing.

Organization modules can be divided into 7 functional groups:

- OM1 Program module that is called cyclically by the system program, and that can be used as a distribution module for the overall program.
- OM<sub>2</sub> Non-executable definition module (initialisation table) containing definitions for the controller system (residual limits, etc.) that are declared by modifying certain table entries.
- Start-up modules that process various program sequences OM5, OM7 during a controller power-up or restart.
- OM8 Module that is called upon shutdown; here the application can be brought to a defined state.
- OM9 Error module that processes reactions when program errors occur.
- OM18-25 Time-controlled processing (time scale can be defined in OM2).
- OM30-63 Reserved.

The OM1 module must be concluded with either the EP (end of program) or EM (end of module) instruction to ensure subsequent processing of the input/output cycle (I/O state). With the exception of the OM2, all other organization modules can be concluded with either EP or EM, depending on the respective tasks being carried out.

#### 5.3.2 Program modules

The program modules (PM) contain program segments that are technically and functionally interrelated. From within program modules, any number of additional program modules and data modules may be called. In addition, all program modules have access to the entire command set of the PLC. The modules are not subject to a size limit.

As a rule, program modules are concluded with an End of Module (EM) instruction. If end of program (EP) is used, after it has been processed, a program end follows and the I/O cycle is carried out. Then further program processing begins again with the OM1.

Due to the option of parameterisation, the program modules may be written independently of absolute operands. During the module call-up, the operands required for the current processing task are transferred to the program module in the form of parameter values.

The following parameters can be declared:

- Input parameters: Operands, constants and modules
- Output parameters: Operands
- I/O parameters: Operands

#### 5.3.3 Data modules

The data modules (DM) serve as storage areas for all fixed and variable values and text blocks that are used by the program. Therefore, during PLC program processing, the user has the option of always keeping two data modules enabled, each of which provides up to 512 bytes of memory capacity.

The following applies to the processing of data modules:

- Before their respective data may be accessed, the data modules must be enabled from within the program by means of module call instructions (i.e., CM for the 1st DM, and CX for the 2nd DM).
- Within a given organization module (OM) or program module (PM), the data modules remain current until other data modules are enabled by the program.
- After the return to the primary module, the data modules active at the time of the call-up of the base module are again activated.
- When the OM1 (cyclical program processing), and the start-up modules OM5 and OM7 are called, no data module is active as yet.

#### 5.3.4 APS modules

The functions of the APS modules (PLC application modules) are integrated into the firmware and the modules themselves merely contain the frame for the actual function calls. This ensures that the APS functions always fit the NC software. The mandatory call of the B01APSMN module at the start of the OM1 is also dropped as this function is carried out within the firmware at the start of PLC processing.

- In the PNC no access to the serial interfaces via the APS modules are supported.
- If an existing program is taken over by an ICL project, the ICL project APS modules have to be replaced by iPCL APS modules. The integration of the program modules NcsLibW.pxh, IcILib.pxl, B01Apsmn.pxl and B06Lgana.pxl can be ignored.

#### 5.4 Program Processing



The application program is processed cyclically and can be interrupted by time- or interrupt-controlled instructions.

#### Cyclical program processing

Once the iPCL has been initialised successfully, the actual program cycle begins in OM1 with the first command of the application program. The cycle time is measured from and until this point in time.

Subsequent to program processing, the processing of inputs and outputs and servicing of communication partners occurs before the cyclical processing continues.

#### Time-controlled program processing

In the course of cyclical program processing, the program sequence can be interrupted by elapsed times that can be defined in the time matrix. In this process, interruption points are only module changes (calling a data module does not rate as a module change). Program processing branches into an OM that is directly assigned to time-controlled processing, processes the program contained therein, and then returns to the interruption point.

In the event that the user avails himself of program module calls from within time OMs, he should disable any other time-controlled processes. See also Section Fehler! Es wurde kein Textmarkenname vergeben.5.16.

### 5.5 Time Monitoring

|             |                       | The entire program processing, i.e. the PLC cycle, is subject to time monitor-<br>ing. Cycle time monitoring is used for this.<br>Cycle time monitoring comprises a security function that can be individually<br>adjusted. Appropriate selection functions are provided in the OM2 initialisa-<br>tion table (see Section 5.7). If the OM2 is not linked to the controller program,<br>this time will have a default value of 1.5 sec. |
|-------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5.6         | I/O state             |                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|             |                       | The I/O state is always started after an EP (end of program) instruction, and processes the image update for peripheral operation, the processing of fix-<br>ations and that of times / timers.                                                                                                                                                                                                                                         |
| 5.6.1       | Fixing inputs, output | uts & markers                                                                                                                                                                                                                                                                                                                                                                                                                           |
|             |                       | The fixation imposes a fixed status mask on inputs, outputs and markers. The resulting fixation masks are placed over the I/O images and markers in each I/O state.                                                                                                                                                                                                                                                                     |
|             |                       | The fixation data are saved in a file in the controller filing system and are re-<br>loaded from there on startup. This file is updated with all changes to the fix-<br>ation masks.                                                                                                                                                                                                                                                    |
|             |                       | The resetting of fixations can be carried out via the program unit (WinSPS) or via PNC control.                                                                                                                                                                                                                                                                                                                                         |
|             |                       | The special marker SM20.4 indicates whether a fixation is active, i.e., at least one bit is fixed.                                                                                                                                                                                                                                                                                                                                      |
| Fixed input | S                     | Prior to entering the OM1 of the PLC program, the loaded status (input image) is covered by the fixation mask. As a consequence, all input queries return the status taken from the fixation mask as long as they have not been changed by the PLC program.                                                                                                                                                                             |
| Fixed outpu | uts                   | Prior to the data exchange with the machine, the output status (output image) is covered by the fixation mask. As a consequence, all process outputs have the status imposed by the fixation mask.                                                                                                                                                                                                                                      |

**Fixed markers** 

Prior to entering the OM1 of the PLC program, the status of the markers from the preceding PLC cycle is covered by the fixation mask. However, the queries within the PLC program will return the fixed status only until the program overwrites them.

#### 5.6.2 Updating timers

Depending on the selected time matrix (resolution), the timers are updated also during the I/O state. This means that the accuracy of the timer loops with respect to the selected time matrix amounts to plus one PLC cycle (max.) including the I/O state.

#### 5.6.3 Cyclical processing

See Section 5.4

#### 5.6.4 Application program structure

With the aim of providing a clear overview of the basic organization of program management, the following diagram shows an example of the program structure.

#### Program startup, one-time only

| OM5, OM7 |
|----------|
| Program  |
| PE       |

#### Program processing, cyclical



#### Time-controlled program processing

Processing always commences subsequent to the change of module (not module call) that follows the expiry of the associated time interval.

| OM18-OM25 |
|-----------|
| Program   |
| EM        |

#### Program processing subsequent to a program error

Processing always occurs upon the occurrence of the triggering criterion.

| OM9     |  |
|---------|--|
| Program |  |
| PE      |  |

#### 5.7 Initialisation table OM2

The OM2 is a system initialisation table that can be linked to the PLC program as required. You will find a pre-configured module named OM2iPCL on the WinSPS path of your programming unit.

An PLC program working without an OM2 utilizes pre-selected default values that are sufficiently useful for many applications.

Deviations from the pre-selected system defaults are declared in the OM2 through manipulation of the entered values. It is essential that the user neither removes nor adds DEFW instructions.

This may be used for example, to shift residual limits, set cycle time limits, etc.

The time matrix definition for the time OMs is also handled in the OM2.

The declarations and definitions stored in the OM2 are adopted by the system upon Power-ON or in the case of a STOP/RUN command, even before processing a startup OM that may be present; a part of the OM2 is copied into the system area.

The following printouts of an OM2 exemplify all options of exercising control over the system initialisation:

#### 5.7.1 Printout of the OM2iPCL

```
;***
                                                ***
;***
                                                ***
        INITIALIZATION TABLE
;***
                                                ***
;***
                                                ***
                  'i P C L'
;***
                                                ***
***
*** Last modification: 21.03.01, be
; OM2 : iPCL Initialisation table
;
    - Must be integrated into each application program;
;
     that uses different default settings.
;
;
   - If no OM2 entry is made in the symbol file,
;
     default settings will be used.
;
;
;
     I M P O R T A N T \, N O T E , please observe in any case
     _____
;
;
    EACH change of data words (W) in forbidden address ranges
;
     ====
;
     may result in undefined PLC system performance.
;
;
;
;DW 1: free
;-----
DEFW W 16#0000
;
;DW 2: Initialisation flag (entries permitted)
;------
  Entry 0 = DO NOT test or execute function
;
   Entry 1 = Verify and/or execute function
;
DEFW W 2#0000000000000000
      *****
                     *: not used
;
              |||+----- Check nominal cycle time
;
              | +----- Residual start if possible
;
              +----- Suppress cycle time monitoring
;
                      during startup
;
              +----- Max. I/O range for MMIMADAP diagnostics
;
           +----- Copy data module to data buffer
;
;
;DW 3: System settings (entries permitted)
;---
   _____
   Entry 0 = DO NOT test or execute function
;
   Entry 1 = Verify and/or execute function
;
DEFW W 2#00000000000000000
      *******
                      *: not used
;
             ||||||+----- Markers \ residual areas for
;
                                \ for cyclical backup
\static RAM, as per
/defined residual
             |||||+---- Timers
;
             ||||+----- Counters
|||+----- Data field
;
;
             ||+----- Data buffer / limits
;
             +---- Data modules /
;
             +----- Cyclical backup of marked areas/ranges.
;
```



```
;
;DW 4: free
;-----
DEFW W 16#0000
;
;DW 5: Maximum cycle time (entries permitted)
;------
   Entries from 1 to 150 in multiples of time base 10 ms possible
;
    (10 ms to 1500 ms) for cycle time monitoring.
;
    Function execution at DW2 / Bit 1 = 1.
;
:
DEFW W 150
;
;DW 6: Copy data module to data buffer (entries permitted)
;---
          _____
   Entry of 0 - 1023 (data module number 0 - 1023) possible.
;
    (Function execution at DW 2 / Bit 8 = 1).
;
DEFW W 0
;
;DW 7: Number of first residual time (entries permitted)
;-----
   Entries from 0 to 256 are possible
;
    128 = Residual for timer loops T128 through T255
;
    256 = No residual
;
DEFW W 128
;
;DW 8: Number of first residual counter (entries permitted)
;---
    Entries from 0 to 256 are possible
;
    128 = Residual for counters Z128 to Z255
;
   256 = No residual
;
DEFW W 128
;
;DW 9: Number of first residual marker (entries permitted)
      _____
;---
    Entries from 0 to 8192 are possible
;
    4096 = Residual from marker byte M4096/marker bit M4096.0;
;
         definition of residual limit via byte addresses
;
    8192 = No residual
;
DEFW W 4096
;
;$P
;DW 10: First residual address in data buffer (entries permitted)
    _____
; ---
    Entries from 0 to 512 are possible
;
    256 = Residual from data buffer byte DP256
;
    512 = No residual
;
DEFW W 256
;
;
    Definition of timer OMs (entries permitted)
;
    _____
;
    Entries as multiplier of base time 10 ms from 1 to 65535
;
     possible
;
    e.g. 0 = no timer-based processing
;
       11 = 11 x 10 ms = 110 ms interval of processing time
;
```

;

```
;DW 11: time OM18
;-----
DEFW W 0
;DW 12: time OM19
;-----
DEFW W 0
;DW 13: time OM20
;-----
DEFW W 0
;DW 14: timer OM21
·-----
DEFW W 0
;DW 15: time OM22
;-----
DEFW W 0
;DW 16: time OM23
;-----
DEFW W 0
;DW 17: time OM24
;-----
DEFW W 0
;DW 18: time OM25
;-----
DEFW W 0
;
;$P
;DW 19 - DW 32: empty
·-----
DEFW W 16#0000 ;DW19
DEFW W 16#0000 ;DW20
DEFW W 16#0000 ;DW21
              ;DW22
DEFW W 16#0000
              ;DW23
DEFW W 16#0000
DEFW W 16#0000
               ;DW24
DEFW W 16#0000
               ;DW25
DEFW W 16#0000 ;DW26
DEFW W 16#0000 ;DW27
DEFW W 16#0000 ;DW28
DEFW W 16#0000
              ;DW29
              ;DW30
DEFW W 16#0000
DEFW W 16#0000
               ;DW31
DEFW W 16#0000
               ;DW32
;DW 33: First residual address in data field for backup to
; static RAM (entries permitted)
;-----
    Entries of 0 and 32768 possible
;
    16384 = Residual from data field byte DF16384 in static RAM
;
    32768 = No residual in static RAMLimit applies only to backup
;
      into static RAM; this areatakes precedence over the data field,
;
      the entire remainder f which is backed up to hard disk for
;
      residual storage;
;
DEFW W 0
;
;DW 34 - DW 101: empty
DEFW W 16#0000 ;DW34
```

| DE<br>DE | FW<br>FW<br>FW<br>FW | W<br>W<br>W<br>W | 16#0000<br>16#0000<br>16#0000<br>16#0000 | ;DW45<br>;DW46<br>;DW47<br>;DW48 |  |
|----------|----------------------|------------------|------------------------------------------|----------------------------------|--|
| DE<br>DE | FW<br>FW<br>FW       | W<br>W<br>W      | 16#0000<br>16#0000<br>16#0000            | ;DW49<br>;DW50<br>;DW51          |  |
| DE<br>DE | FW<br>FW             | W<br>W           | 16#0000<br>16#0000                       | ;DW52<br>;DW53                   |  |
| DE<br>DE | FW<br>FW<br>FW       | W<br>W<br>W      | 16#0000<br>16#0000<br>16#0000            | ;DW54<br>;DW55<br>;DW56          |  |
| DE       | FW<br>FW<br>FW       | พ<br>พ<br>พ      | 16#0000<br>16#0000<br>16#0000            | ; DW5 7<br>; DW5 8<br>; DW5 9    |  |
| DE       | FW<br>FW<br>FW       | พ<br>พ<br>พ      | 16#0000<br>16#0000<br>16#0000            | ;DW60<br>;DW61<br>;DW62          |  |
| DE       | FW<br>FW<br>FW       | พ<br>พ<br>พ      | 16#0000<br>16#0000<br>16#0000            | ;DW63<br>;DW64<br>;DW65          |  |
| DE<br>DE | FW<br>FW<br>FW       | W<br>W<br>W      | 16#0000<br>16#0000<br>16#0000            | ; DW66<br>; DW67<br>; DW68       |  |
| DE<br>DE | FW<br>FW             | W<br>W           | 16#0000<br>16#0000<br>16#0000            | ;DW69<br>;DW70                   |  |
| DE<br>DE | FW<br>FW<br>FW       | W<br>W<br>W      | 16#0000<br>16#0000                       | ;DW71<br>;DW72<br>;DW73          |  |
| DE       | FW<br>FW<br>FW       | พ<br>พ<br>พ      | 16#0000<br>16#0000<br>16#0000            | ;DW74<br>;DW75<br>;DW76          |  |
| DE       | FW<br>FW<br>FW       | พ<br>พ<br>พ      | 16#0000<br>16#0000<br>16#0000            | ;DW77<br>;DW78<br>;DW79          |  |
| DE       | FW<br>FW<br>FW       | พ<br>พ<br>พ      | 16#0000<br>16#0000<br>16#0000            | ;DW80<br>;DW81<br>;DW82          |  |
| DE       | FW<br>FW<br>FW       | พ<br>พ<br>พ      | 16#0000<br>16#0000<br>16#0000            | ;DW83<br>;DW84<br>;DW85          |  |
| DE<br>DE | FW<br>FW<br>FW       | W<br>W<br>W      | 16#0000<br>16#0000<br>16#0000            | ;DW86<br>;DW87<br>;DW88          |  |
| DE<br>DE | FW<br>FW             | W<br>W           | 16#0000<br>16#0000                       | ;DW89<br>;DW90                   |  |
| DE       | FW<br>FW<br>FW       | พ<br>พ<br>พ      | 16#0000<br>16#0000<br>16#0000            | ;DW91<br>;DW92<br>;DW93          |  |
| DE       | FW<br>FW<br>FW       | W<br>W<br>W      | 16#0000<br>16#0000<br>16#0000            | ;DW94<br>;DW95<br>;DW96          |  |

;

Entry 1 = Execute function

```
;
    If the CAN processing is blocked then the
;
    MTB1/MTB2 processing will not be carried out!
;
DEFW W 2#000000000100101
       *******
                           *: not used
;
               || || +---- CAN processing
;
               || |+----- MTB1 processing
;
               || +----- MTB2 processing
;
               +----- CAN actual assignment
;
               +----- Suppress CAN error/warning
;
;DW 98: reserved
;------
DEFW W 16#0000
:
;DW 99: Start address of MTB1 information in the marker area
; (entries permitted)
    The MTB1 data occupy 20 successive bytes in the
;
;
    marker area:
               Meaning: 16 bytes input data
;
                        4 bytes output data
;
   The function must be enabled in DW 97.
;
    Entries from KOD to K6124D (M0 to M6124) are possible.
;
DEFW W 6100
;DW 100: Start address of MTB2 information in the marker area
;----
                _____
;(entries permitted)
   The MTB2 data occupy 20 successive bytes in the
;
    marker area:
;
               Meaning: 16 bytes input data
;
                        4 bytes output data
;
    The function must be enabled in DW 97.
;
    Entries from KOD to K6124D (M0 to M6124) are possible.
;
DEFW W 16#0000
;
;DW 101: Start address of the CAN actual assignment in the marker area
;-----
    ;(entries permitted)
;
    The CAN actual assignment takes up 2 bytes in the marker area
;
    and contains the following information:
;
;
       000000000000000000B
;
       *****
                          *: not used
;
;
                  +----- MTB 1 recognized
;
                 +---- MTB 2 recognized
;
; The function must be enabled in DW 97.
; Entries from KOD to K6124D (M0 to M6124) are possible.
DEFW W 6122
;$P
;
    111
         Internal system memory data
                                    111
;
    ------
;
;The following default settings must not be changed.
;Default value for data words DW 102 - DW 127 = 16#0000
DEFW W 16#0000 ;DW102
```

| DEFW                                    | W | 16#0000 | ;DW103 |  |  |
|-----------------------------------------|---|---------|--------|--|--|
| DEFW                                    | W | 16#0000 | ;DW104 |  |  |
| DEFW                                    | W | 16#0000 | ;DW105 |  |  |
| DEFW                                    | W | 16#0000 | ;DW106 |  |  |
| DEFW                                    | W | 16#0000 | ;DW107 |  |  |
| DEFW                                    | W | 16#0000 | ;DW108 |  |  |
| DEFW                                    | W | 16#0000 | ;DW109 |  |  |
| DEFW                                    | W | 16#0000 | ;DW110 |  |  |
| DEFW                                    | W | 16#0000 | ;DW111 |  |  |
| DEFW                                    | W | 16#0000 | ;DW112 |  |  |
| DEFW                                    | W | 16#0000 | ;DW113 |  |  |
| DEFW                                    | W | 16#0000 | ;DW114 |  |  |
| DEFW                                    | W | 16#0000 | ;DW115 |  |  |
| DEFW                                    | W | 16#0000 | ;DW116 |  |  |
| DEFW                                    | W | 16#0000 | ;DW117 |  |  |
| DEFW                                    | W | 16#0000 | ;DW118 |  |  |
| DEFW                                    | W | 16#0000 | ;DW119 |  |  |
| DEFW                                    | W | 16#0000 | ;DW120 |  |  |
| DEFW                                    | W | 16#0000 | ;DW121 |  |  |
| DEFW                                    | W | 16#0000 | ;DW122 |  |  |
| DEFW                                    | W | 16#0000 | ;DW123 |  |  |
| DEFW                                    | W | 16#0000 | ;DW124 |  |  |
| DEFW                                    | W | 16#0000 | ;DW125 |  |  |
| DEFW                                    | W | 16#0000 | ;DW126 |  |  |
| DEFW                                    | W | 16#0000 | ;DW127 |  |  |
| DEFW                                    | W | 16#0000 | ;DW128 |  |  |
| • * * * * * * * * * * * * * * * * * * * |   |         |        |  |  |
| <u></u>                                 |   |         |        |  |  |

EM

#### 5.8 Module reference list

The module reference list comprises a Table of Contents listing the modules integrated in the PLC program. The list contains information about module existence, module size and module start address.

To extract this data, special instructions are available for the user.

**□** The instructions used to verify module existence, module size and module start address of OMs and PMs can be used only with the WinSPS v3.0 and higher.

#### 5.9 Module existence

#### Example:

```
; Check module existence
;-----
; Checks whether the modules OM8, DM8, and FC8.
; exist
; direct addressing
U OM8 ; OM8 exist?
      DM8 ; DM8 exist?
U
U
     PM8 ; PM8 exist?
; indirect addressing
L D 8,A ; load module no. in register A
U
     OM[A]; OM8 exist?
U
      DM[A]; DM8 exist?
U
     PM[A]; PM8 exist?
```

#### 5.10 Module size

Example:; read module size ;-----; Extracts module lengths of modules OM8, DM8, and PM8. ; direct addressing L D OM8,A; size of OM8 in reg. A DM8,A; size of DM8 in reg. A D L L D PM8,A; size of PM8 in reg. A ; indirect addressing L  $\,$  D  $\,$  8,A  $\,$  ; load module no. in register A  $\,$ L D OM[A],B ; size of OM8 in reg. B L D DM[A],B ; size of DM8 in reg. B L D PM[A],B ; size of PM8 in reg. B

#### 5.11 Module start address

#### Example:

| ; Read module start address                                 |  |  |  |  |  |
|-------------------------------------------------------------|--|--|--|--|--|
| ;                                                           |  |  |  |  |  |
| ; Extracts module start addresses for modules OM8, DM8, and |  |  |  |  |  |
| PM8.                                                        |  |  |  |  |  |
| ; direct addressing                                         |  |  |  |  |  |
| L D $\&OM8, A$ ; start address of the OM8 in reg. A         |  |  |  |  |  |
| L D &DM8,A ; start address of the DM8 in reg. A             |  |  |  |  |  |
| L D &PM8,A ; start address of the PM8 in reg. A             |  |  |  |  |  |
|                                                             |  |  |  |  |  |
| ; indirect addressing                                       |  |  |  |  |  |
| L D 8,A ; load module no. in register A                     |  |  |  |  |  |
| L D &OM[A],B ; start address of the OM8 in reg. B           |  |  |  |  |  |
| L D $\&DM[A],B$ ; start address of the DM8 in reg. B        |  |  |  |  |  |
| L D &PM[A],B ; start address of the PM8 in reg. B           |  |  |  |  |  |
|                                                             |  |  |  |  |  |

#### 5.12 Module header

The module header contains information about the following:

- Module start address
- Module size
- Module version number, generated by the WinSPS module header editor
- Length of module name (currently = max. 8)
- Module name in string notation.

The user can employ a special instruction to evaluate this data. The function of this instruction is explained in the following example.

# IF The commands for checking module headers are available from the WinSPS version onwards.

#### Example:

```
; Write module header contents on marker
;-----
; 20 bytes of the FC100 module header shall be stored
;from marker M20 onwards.
;
; Number of bytes to be read must be in register C.L D
                                                         20,C
; Writing 20 bytes of header information onto an operand.
; The start address of the operand must be a multiple
; of 4 due to the double-word processing.
FC
   D FC100,M20 ; store 20 byte header contents of the FC100
from M20
                    4 bytes (M20-M23): Start address
;
                    4 bytes (M24-M27): Size in bytes
;
                    2 bytes (M28+M29): Version no. from header
;
                             (M30): Length n of module name
                    1 byte
;
                    8+1byte (M31-M39): Module name string with
;
                                      ' \setminus 0' at the end.
;
                    2 bytes
                                     : PXL/PXO code:
;
                                       1 = secret
;
                                       0 = not secret
;
```

The user can utilize this command sequence to read the module header information of OMs, PMs and DMs. It should be noted that DMs do not feature version identifiers in the module header, i.e., the respective bytes have a content = 0.

#### 5.13 OM9 error module

This module is invoked once only in the event that a program error is noted that would normally cause an immediate stop of the central processing control unit. To serve the intended purpose, it must be integrated into the PLC program.

The triggering criteria are defined errors that can be interpreted by setting a special marker bit in SM14 / SM15 and in SM28 / SM29.

Upon calling the OM9, the cycle time monitoring function is restarted with the defined value (definition in OM2 or default value of 1.5 sec). While the module is being processed, countermeasures for possible error occurrences can be programmed.

For example, certain data, including the special error markers, can be moved to non-volatile areas.

Once the OM9 error module has been processed, the PLC enters STOP mode.

#### 5.14 Fixation

The PLC provides the option to fix operands.

In contrast to the "Control" programming device function, this option can be used to fix operands permanently to specific bit statuses or values.

Operands suitable for fixation:

- Inputs
- Outputs
- Markers

#### **Residuals of fixation**

An existing fixation is retained in the following cases:

- Always after a STOP/RUN change in operating mode.
- After a new load.
- Always after a Power-Off/On cycle.

#### 5.15 Parameterized Modules

When a program module is called up, up to 63 parameter values can be transferred. The number of parameters transferred is specified in the module call-up command. Then the parameters follow, starting with P0.

#### Example of parameter transfer

| DEF<br>DEF<br>DEF<br>DEF<br>DEF |   | E0.0,-Start<br>M0,-Target value<br>M2,-Actual value<br>A0.0,-Target_actual<br>A0.0,-No result |   |      |            |                           |
|---------------------------------|---|-----------------------------------------------------------------------------------------------|---|------|------------|---------------------------|
| ;<br>BA                         |   | -TARGET ACTUAL,                                                                               | 5 |      |            |                           |
| ;                               |   | _                                                                                             |   |      |            |                           |
| ;                               |   |                                                                                               |   | +    |            | ÷                         |
| PO                              |   | -Start                                                                                        | ; | BOOL | VAR_INPUT  | Signal for function start |
| P1                              | W | -Target value                                                                                 | ; | WORD | VAR_IN_OUT | expected number           |
| P2                              | W | -Actual value                                                                                 | ; | WORD | VAR_INPUT  | actual number             |
| P3                              |   | -Target_actual                                                                                | ; | BOOL | VAR_IN_OUT | target value reached      |
| P4                              |   | -No result                                                                                    | ; | BOOL | VAR_OUTPUT | no valid reading          |
| ;                               |   |                                                                                               |   | +    | +          | ÷                         |

Utilization of parameters in called-up module:

| +   |        |      |       |               |            | +                          |
|-----|--------|------|-------|---------------|------------|----------------------------|
| hea |        |      |       |               |            |                            |
|     | P0     |      | DOL   |               |            |                            |
|     | P1     | W    | DRD   | Target value  | VAR_IN_OUT | expected number            |
|     | P2     | W    | ORD   | Actual value  | VAR_INPUT  | actual number              |
|     | Р3     | B    | DOL   | Target_actual | VAR_IN_OUT | target value reached       |
|     | Ρ4     | B    | DOL   | no result     | VAR_OUTPUT | no valid reading           |
| + - |        |      |       |               |            | +                          |
|     | rogram |      |       |               |            |                            |
| + - |        |      |       |               |            | +                          |
|     | ; Com  | npai | ce va | lues          |            |                            |
| 1   | U      |      | -Sta  | rt            | PO         | Signal for function start  |
| 2   | SPI    |      | no c  | omparison     |            |                            |
| 3   | L      | W    | -Tar  | get value,A   | P1         | expected number            |
| 4   | VGLA   | W    | -Act  | ual value,A   | P2         | actual number              |
| 5   | U      |      | Ζ     |               | ;          | Result=0> values are equal |
| 6   | =      |      | -Tar  | get_actual    | P3         | target value reached       |
| 7   | R      |      | -No   | result        | P4         | no valid reading           |
|     | no co  | ompa | ariso | n:            |            |                            |
|     | ; Del  | ete  | e com | pare result   |            |                            |
| 8   | UN     |      | -Sta  | rt            | PO         | Signal for function start  |
| 9   | R      |      | -Tar  | get_actual    | P3         | target value reached       |
| 10  | S      |      | -No   | result        | P4         | no valid reading           |

11 EM

#### 5.16 Time-controlled program processing

iPCL provides the option of time-controlled program processing.

For time-controlled processing 8 timer OMs are provided that interrupt the program at predefined intervals to activate one of these modules. The timer resolution (matrix) is defined in the OM2.

A timer OM is called up if:

- 1. The designated time interval has expired and
- 2. a change of module has been reached.

Defined module changes are an executed module call, as well as an end of module. Neither a DM call-up nor an EP instruction is considered a change of module. Within the group of timer interrupts, the highest priority is given to the interrupt that is assigned to the lowest OM number.

OM18 = highest priority, OM25 = lowest priority

**□** Because some programs utilize the register contents across module boundaries (e.g., MADAP with the KETTEPCL program module), the register contents should always be backed up upon entry into a timer OM, and again updated prior to the end of module (PUSH/POP).

# Commands for handling timer interrupts

The time-controlled interrupts (TI) are assigned an interrupt mask. This mask can be read and written to with the use of the TIM and LIM instructions, respectively. Each possible timer interrupt corresponds to one bit in this mask. When a bit is set, this means that the respective interrupt has been enabled; when the bit is not set, the interrupt is disabled.

To perform the actual enabling of the interrupts declared in the mask, the additional instruction EAI (Enable All Interrupts) must be issued. A general disabling of the interrupts without influencing the mask is accomplished with the DAI (Disable All Interrupts) instruction.

Incoming interrupts cause an entry in the corresponding interrupt register even in cases where the respective interrupts have been masked. Here again, a bit is assigned to each timer interrupt.

If the interrupt is executable, i.e. enabled, calling the interrupt OM automatically deletes the bit in the interrupt register.

When the interrupt is disabled, the bit remains in the register, and the interrupt awaits its being enabled.

The interrupt register can be loaded using the LAI (Load All Interrupts) instruction, and active interrupts can be deleted with the RAI (Reset All Interrupts) instruction.

A change of operating mode, i.e. STOP/RUN or Power-Off/On, deletes all active interrupts.

By default, all time controlled interrupts are enabled.

During the startup procedure, i.e. processing of OM5 and OM7, all interrupts remain disabled.

#### 5.17 Application stack

The application stack (AST) comprises a pushdown-pop-up memory stack with a storage depth of 256 double words, using FILO (first-in-last-out) processing.

The PUSH and POP instructions facilitate a word-by-word data transfer between the registers and the contents of the application stack.

#### Example:

PUSH A  $% \left( A \right) = \left( A \right) \left( A \right$ B ;Shift contents of register B to applic. stack PUSH C ;Shift contents of register C to applic. stack PUSH D ;Shift contents of register D to applic. stack PUSH POP D ;Load uppermost value from applic.stack into Reg.D POP С ;Load uppermost value from applic.stack into Reg.C POP В ;Load uppermost value from applic.stack into Reg.B POP A ;Load uppermost value from applic.stack into Reg.A

In the event of an application stack underflow, special marker bit S28.4 will be set to ON.

In the case of an application stack overflow, special marker bit S28.5 will be set to ON. Both application stack (AST) underflow and overflow conditions will cause the central processing module to enter STOP mode, returning an error message indicating the cause of the error.

The application stack is flushed after each EP!

# 6 iPCL addressing

## 6.1 Operand & module identifiers, module list

| Abbrev.    | Indexed | Operand                         | Access / Data width                            | Image update |
|------------|---------|---------------------------------|------------------------------------------------|--------------|
| A, B, C, D |         | General computingre-<br>gisters | Bit, byte, word, double word, REAL,LREAL       |              |
| I          | I[R]    | Input                           | Image/Bit, byte, word, double word, REAL,LREAL | I/O state    |
| 0          | 0[R]    | Output                          | Image/Bit, byte, word, double word, REAL,LREAL | I/O state    |
| М          | M[R]    | Markers                         | Bit, byte, word, double word, REAL, LongREAL   |              |
| SM         | SM[R]   | Special marker                  | Bit, byte, word, double word, REAL, LongREAL   |              |
| Т          | T[R]    | Timer                           | Bit (status), word (value)                     |              |
| Z          | Z[R]    | Counters                        | Bit (status), word (value)                     |              |
| D          | D[R]    | Data word, 1st current          | Bit, byte, word, double word, REAL,LREAL       |              |
| DX         | DX[R]   | DM                              |                                                |              |
|            |         | Data word, 2nd cur-<br>rent DM  |                                                |              |
| DM         | DM[R]   | Data buffer                     | Bit, byte, word, double word, REAL,LREAL       |              |
| DF         | DF[R]   | Data field                      | Bit, byte, word, double word, REAL,LREAL       |              |
| S          | S[R]    | System data range               | Bit, byte, word, REAL, LREAL                   |              |
| Р          | P[R]    | Parameter                       | Bit, byte, word, double word                   |              |
| FI         |         | FIFO                            | Max. 512 bytes                                 |              |
| TI         |         | Time-controlled inter-<br>rupt  |                                                |              |
| b#www      |         | Constants                       | Bit, byte, word, double word, REAL,LREAL       |              |
| DM         | DM[R]   | Data module                     | CM DMnn ; calls 1st DM                         |              |
| PM         | PM[R]   | Program module                  | BX DMnn ; calls 2nd DM                         |              |

In the above enumeration, "R" is replaced by the register IDs "A", "B", "C" or "D".

#### Module list

iPCL manages the following modules:

| Name         | Function                      | Comment                                                                           |
|--------------|-------------------------------|-----------------------------------------------------------------------------------|
| OM1          | Cyclical program processing   |                                                                                   |
| OM2          | Initialisation table          | Refer to Section 5.7 "Initialisation Table"                                       |
| OM5          | Startup module after Power-ON |                                                                                   |
| OM7          | Startup module after STOP/RUN |                                                                                   |
| OM8          | Shutdown module               |                                                                                   |
| OM18-OM25    | Time-controlled modules       | Matrix agreement in the OM2 or S18 – S32,<br>lowest module no. = highest priority |
| OM42 - OM63  | reserved                      |                                                                                   |
| PM0 – PM1023 | Program modules               |                                                                                   |
| DM0 – DM1023 | Data modules                  |                                                                                   |

#### 6.2 Assignments in the special marker area

The iPCL features a special marker area with a size of 16-words i.e. SM0 through SM30. It contains essential information regarding system flags and PLC cycle time.

The unused addresses are reserved for internal system functions, and must not be changed.

| Address | Conter | nts                                                                                                   | Comment |
|---------|--------|-------------------------------------------------------------------------------------------------------|---------|
| SM14    | PLC pr | ogram and system error messages:                                                                      |         |
|         | Hex    |                                                                                                       |         |
|         | 12     | Cycle time error                                                                                      |         |
|         | 16     | Module stack overflow                                                                                 |         |
|         | 17     | Application stack overflow                                                                            |         |
|         | 18     | Application stack underflow                                                                           |         |
|         | 19     | DM too short                                                                                          |         |
|         | 1A     | Operation code error                                                                                  |         |
|         | 1B     | Parameter error                                                                                       |         |
|         | 1C     | Parameter not found                                                                                   |         |
|         | 1D     | Address error, access to invalid address, e.g. transfer to constant or timer or actual counter value. |         |
|         | 1E     | Not available PB called up                                                                            |         |
|         | 1F     | Not available DM called up                                                                            |         |
|         | 20     | Halt command                                                                                          |         |
|         | 21     | Controller in STOP                                                                                    |         |
|         | 22     | Hardware error                                                                                        |         |
|         | 23     | "C" application error                                                                                 |         |
|         | 24     | "C" application warning                                                                               |         |
|         | 25     | Re-entrant module call                                                                                |         |
|         | 26     | Assignment list error                                                                                 |         |
|         | 27     | No PLC program                                                                                        |         |
|         | 28     | Error in call for peripheral driver                                                                   |         |
|         | 29     | Error in installation of peripheral driver                                                            |         |
|         | 2B     | Not available Interr. OM                                                                              |         |
|         | 2C     | Instruction not yet integrated                                                                        |         |
|         | 2D     | Error in indirect jump                                                                                |         |
|         | 2E     | Wrong operand number                                                                                  |         |
|         | 2F     | DM not active                                                                                         |         |
|         | 30     | Illegal DM size                                                                                       |         |
|         | 31     | Non-reproducible error                                                                                |         |
|         | 41     | System software error                                                                                 |         |
| SM16    |        |                                                                                                       |         |
| SM18    |        |                                                                                                       |         |

| Address | Contents        |                                                         | Comment                                                       |
|---------|-----------------|---------------------------------------------------------|---------------------------------------------------------------|
| SM20    | Bit             |                                                         | Read-only for entire bit field                                |
|         | 20.0            | Trigger pulse upon each startup                         | ,                                                             |
|         | 20.1            | Buffer failure                                          | = 1, SNCI4: Memory fields to static RAM                       |
|         | 20.2            | Flashing marker                                         | , ,                                                           |
|         | 20.3            | Outputs disabled                                        |                                                               |
|         | 20.4            | Fixation active                                         |                                                               |
|         | 20.5            | Data backup error                                       | = 1, PNC: Memory fields of the residual data on the hard disk |
|         | 20.6<br>20.7    | Cold start flag<br>Trigger pulse after power ON or load |                                                               |
| SM22    | 20.7            |                                                         | Dead ank                                                      |
|         |                 | Actual cycle time of last complete cycle                | Read-only                                                     |
| SM24    |                 | Maximum measured cycle time                             |                                                               |
| SM26    |                 | Minimum measured cycle time                             |                                                               |
| SM28    | Error<br>word 1 |                                                         | All errors are read-only                                      |
|         | 28.0            | Addressing error                                        |                                                               |
|         | 28.1            | Parameter error                                         |                                                               |
|         | 28.2            | Non-existent module called                              |                                                               |
|         | 28.3            | Module stack error                                      |                                                               |
|         | 28.4            | AST underflow                                           |                                                               |
|         | 28.5            | AST overflow                                            |                                                               |
|         | 28.6            |                                                         |                                                               |
|         | 28.7            |                                                         |                                                               |
| SM29    | Error<br>word 1 |                                                         |                                                               |
|         | 29.0            |                                                         |                                                               |
|         | 29.1            | Opcode error                                            |                                                               |
|         | 29.2            |                                                         |                                                               |
|         | 29.3            |                                                         |                                                               |
|         | 29.4            |                                                         |                                                               |
|         | 29.5            | No DM active                                            |                                                               |
|         | 29.6            | Group error message                                     | For detailed information, refer to SM14.                      |
|         | 29.0            | Cycle time error                                        |                                                               |
| 01400   |                 |                                                         |                                                               |
| SM30    | Auxiliary       |                                                         | All errors are read-only                                      |
|         | marker<br>word  |                                                         |                                                               |
|         | 30.0            |                                                         |                                                               |
|         | 30.1            |                                                         |                                                               |
|         | 30.2            |                                                         |                                                               |
|         | 30.3            | Always 0                                                |                                                               |
|         | 30.4            |                                                         |                                                               |
|         | 30.4            |                                                         |                                                               |
|         | 30.6            |                                                         |                                                               |
|         | 30.7            |                                                         |                                                               |
| SM31    | Auxiliary       |                                                         |                                                               |
|         | marker          |                                                         |                                                               |
|         | word            |                                                         | Influenced only by CPL instruction                            |
|         | 31.0            | Logical greater flag                                    |                                                               |
|         | 31.1            | Always 1                                                |                                                               |
|         | 31.2            | / wayo i                                                |                                                               |
|         | 31.3            |                                                         |                                                               |
|         | 31.4            |                                                         |                                                               |
|         | 31.4            |                                                         |                                                               |
|         | 31.5            |                                                         |                                                               |
|         | 31.0            | Carry flag, logical less when 1                         | Influenced only by CPL instruction                            |
|         | 01.7            | Zero flag, logical equal when 1                         | Influenced only by CPL instruction                            |

#### 6.3 System area assignment

iPCL features a system area with a size of 512 bytes i.e. S0 through S511. It contains the system configuration data for the respective controller. Essential declarations made in OM2 are copied into the system area, and can thus be read by the PLC program.

To the extent deemed useful, the system declarations may be changed at runtime. This also includes the time intervals of time-controlled organization modules.

Segments of the system area are used by default function modules which make data available that is also used by other PLC program parts.

Example: Date and time.

The unassigned addresses in the system area are reserved for internal purposes, and must not be modified.

| Address | Contents            |                                 | Comment                                                           |
|---------|---------------------|---------------------------------|-------------------------------------------------------------------|
| S0      | Initialisation flag | s like OM2_DW2                  | Writing in OM5 / OM7                                              |
| S2      | System settings     | like OM2_DW3                    |                                                                   |
| S4      | Error reaction lik  | e OM2_DW4                       | Writing in OM5 / OM7                                              |
| S6      | Maximum cycle       | time like OM2_DW5               | Writing in OM5 / OM7                                              |
| S8      | DM to be copied     | like OM2_DW6                    | Read-only                                                         |
| S10     | First residual tim  | ne like OM2_DW7                 | Writing in OM5 / OM7                                              |
| S12     | First residual co   | unter like OM2_DW8              | Writing in OM5 / OM7                                              |
| S14     | First residual ma   | arker address like OM2_DW9      | Writing in OM5 / OM7                                              |
| S16     | First residual da   | ta buffer address like OM2_DW10 | Writing in OM5 / OM7                                              |
| S18     | Time interval ON    | /18 like OM2_DW11               | Transfer during startup and                                       |
| S20     | Time interval ON    | /19 like OM2_DW12               | EP, possibly active timer must<br>expire before new matrix is ac- |
| S22     | Time interval ON    | /20 like OM2_DW13               | tivated.                                                          |
| S24     | Time interval ON    | /21 like OM2_DW14               |                                                                   |
| S26     | Time interval ON    | /22 like OM2_DW15               |                                                                   |
| S28     | Time interval ON    | /23 like OM2_DW16               |                                                                   |
| S30     | Time interval ON    | /124 like OM2_DW17              |                                                                   |
| S32     | Time interval ON    | /25 like OM2_DW18               |                                                                   |
| S62     | First residual da   | ta field address like OM2 DW33  |                                                                   |
| S64     | Current process     | ing time, in microseconds       | Program run time OM1 start through I/O state end.                 |
| S66     | Current process     | ing time, in milliseconds       |                                                                   |
| S68     | Max. processing     | time, in microseconds           |                                                                   |
| S70     | Max. processing     | time, in milliseconds           |                                                                   |
| S72     | Min. processing     | time, in microseconds           |                                                                   |
| S74     | Min. processing     | time, in milliseconds           |                                                                   |
| S76     | Min. processing     | time, in microseconds           | RUN = READY contact closed                                        |
| S100    | Real-time:          | Minutes / seconds               | Read-only                                                         |
| S102    |                     | Day/ hours                      | Entry from operating system                                       |
| S104    |                     | Year / month                    | 0=So, 1= Mo, , 6=Sa                                               |
| S106    |                     | Week day :                      |                                                                   |

| See Section Periphery status<br>See Section iPCL startup char-<br>acteristics<br>I/O information<br>SNCI4: 0.5 KbytesPNC 8<br>Kbytes |
|--------------------------------------------------------------------------------------------------------------------------------------|
| I/O information<br>SNCI4: 0.5 KbytesPNC 8                                                                                            |
| SNCI4: 0.5 KbytesPNC 8                                                                                                               |
| SNCI4: 0.5 KbytesPNC 8                                                                                                               |
|                                                                                                                                      |
|                                                                                                                                      |
|                                                                                                                                      |
| DCIO PROFIBUS-DP<br>(with SNCI4)                                                                                                     |
| PNC PROFIBUS-DP<br>(with PNC)                                                                                                        |
|                                                                                                                                      |
| Bit state:<br>0 = Slave working error free<br>1 = Slave reports diagnostics<br>(cannot be contacted or re-<br>ports an error)        |
|                                                                                                                                      |

#### 6.4 **Periphery status**

The periphery status word S114 provides an overview of the status of the bus master; it has the following format:

| Bit |        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | BMF    | Bus master error                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1   | KSD    | Classified slave diagnostics: The KSD bit in the DP status<br>word is the OR link of bits 8 to 13. The individual error types<br>of the KSD are shown in bits 8 to 13 of the DP status word.                                                                                                                                                                                                                                                                                   |
| 2   | SD     | System diagnostics: The DP standard differentiates between<br>system diagnostics and slave diagnostics. System diagnos-<br>tics comprise a bit field that indicates which slaves report<br>diagnostics. In addition, there is a detailed diagnostic routine<br>for individual slaves, the slave diagnostics. The SD bit in the<br>DP status word represents the OR link of all system diagnos-<br>tic bits. Therefore, when SD = 1, at least one slave reports<br>diagnostics. |
| 3   |        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 4   | Init   | Init phase: Waiting until periphery is ready for operations, or until iPLC STOP time has elapsed.                                                                                                                                                                                                                                                                                                                                                                              |
| 5   | BmClab | Bus master has switched DP bus to CLEAR status: BmClab = [SNE v SKF v SNB] & Error_Action_Flag = 1. The point in time for the restart after discontinuation of the BmClab causes can be controlled from the PLC program.                                                                                                                                                                                                                                                       |
| 6   | PgStop | Programming unit keeps DP bus in STOP state.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7   | Active | Active ID: This bit must always be 1. If that is not the case, then there is a fatal error in the bus master software.                                                                                                                                                                                                                                                                                                                                                         |
| 8   | SNE    | One or more slaves are not reachable on the bus.                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 9   | SKF    | One or more slaves report configuration errors.                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 10  | DPS    | One or more slaves report static diagnostics.                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 11  | EXD    | One or more slaves report extended diagnostics.                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 12  | SNB    | One or more slaves not ready for cyclical data exchange.                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 13  | SF     | One or more slaves report error of another type.                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 14  |        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15  |        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

The bits **Init**, **BmClab**, **PgStop** are not relevant to the PLC program because, in the RUN state of the iPCL, they always have the value 0..

Bus master error (BMF)

This bit indicates that a bus master error has been detected.

#### **KSD – Classified Slave Diagnostics**

The KSD bit in the DP status word is the OR link of bits 8 to 13. The individual error types of the KSD are shown in bits 8 to 13 of the DP status word.

#### System diagnostics in accordance with DP standards (SD)

|           | The DP standard differentiates between system diagnostics and slave diagnostics. System diagnostics comprise a bit field that indicates which slaves report diagnostics. In addition, there is a detailed diagnostic routine for individual slaves, the slave diagnostics.<br>The SD bit in the DP status word represents the OR link of all system diagnostic bits. Therefore, when SD = 1, at least one slave reports diagnostics. |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Active ID | This bit must always be 1. If that is not the case then there is a fatal error in the bus master software.                                                                                                                                                                                                                                                                                                                           |

#### 6.5 Data formats

Bit, byte, word and double word can all be specified as **data formats** . In the **addressing** differentiation is made between:

- Load instruction
- Transfer instruction

Bit



Byte = B



On loading, the source operand may be either the even-numbered (LOW) byte or the odd-numbered (HIGH) byte. In the case of the destination operand (register), the LOW byte is always addressed.

#### Example: Load command (byte): M1



| Register A         |      |           |          |  |  |
|--------------------|------|-----------|----------|--|--|
| High               | word | Low word  |          |  |  |
| High byte Low byte |      | High byte | Low byte |  |  |

#### Example: Load command (byte): M2



On transfer the LOW byte is addressed in the source operand (register). The destination operand may be either the even-numbered (LOW) byte or the odd-numbered (HIGH) byte.

#### Example: Transfer command (word): M1

| Т | В                  | A,M1 |           |          |  |  |  |
|---|--------------------|------|-----------|----------|--|--|--|
|   | Register A         |      |           |          |  |  |  |
|   | High               | word | Low       | word     |  |  |  |
|   | High byte Low byte |      | High byte | Low byte |  |  |  |
|   | M1                 |      |           |          |  |  |  |
|   | High byte Low byte |      |           |          |  |  |  |

#### Example: Transfer command (word): M2

| Т | B A, M2            |          |           |          |  |  |
|---|--------------------|----------|-----------|----------|--|--|
|   | Register A         |          |           |          |  |  |
|   | High               | word     | Low       | word     |  |  |
|   | High byte Low byte |          | High byte | Low byte |  |  |
|   |                    |          | ]         |          |  |  |
|   |                    | M2       |           |          |  |  |
|   | High byte          | Low byte |           |          |  |  |

#### Word = W

| High word |           | Low word |           |          |
|-----------|-----------|----------|-----------|----------|
|           | High byte | Low byte | High byte | Low byte |
| 31        | 24        | 23 1     | 6 15      | 87 0     |

An even-numbered or odd-numbered byte address may be specified for word processing during the load or transfer instructions.

Without exception, for the **load** instruction, the specified byte and the subsequent byte are loaded into the LOW word of the register (32-bit); the HIGH word of the register remains unchanged.

Without exception, for the **transfer** instruction, the specified byte and the subsequent byte are written from the LOW word of the register (32-bit).

#### Example: Load command (word): M2

L W M2 , A M2 High byte Low byte

| Register A |          |           |          |  |
|------------|----------|-----------|----------|--|
| High       | word     | Low word  |          |  |
| High byte  | Low byte | High byte | Low byte |  |

#### Double word = D

|    | High word |          |       | Low word  |          |   |
|----|-----------|----------|-------|-----------|----------|---|
|    | High byte | Low byte |       | High byte | Low byte |   |
| 31 | 24        | 23       | 16 15 | 8         | 37       | 0 |

**Loading** always requires the base byte and the following 3 bytes to be loaded into the specified register (32-bit).

**Transferring** always requires the specified register (32-bit) to be written to the base byte and the following 3 bytes.

Example: Load command (double word): M4

L D M4,A

|           |          |           | M4       |
|-----------|----------|-----------|----------|
| High byte | Low byte | High byte | Low byte |

| Register A         |  |           |          |  |
|--------------------|--|-----------|----------|--|
| High word Low word |  |           |          |  |
| High byte Low byte |  | High byte | Low byte |  |



#### Example: Transfer command (double word): M4

T D A,M4

| Register A |          |           |          |  |
|------------|----------|-----------|----------|--|
| High       | word     | Low       | word     |  |
| High byte  | Low byte | High byte | Low byte |  |

|           |          |           | M4       |
|-----------|----------|-----------|----------|
| High byte | Low byte | High byte | Low byte |

#### Example: Transfer command (double word): M3

Error in the PG.

| L | D | 3,C |
|---|---|-----|
|   |   |     |

| Т | D | A,M[C] |
|---|---|--------|
|   |   |        |

| Register A |          |           |          |  |
|------------|----------|-----------|----------|--|
| High       | word     | Low       | word     |  |
| High byte  | Low byte | High byte | Low byte |  |

|           |          |           | МЗ       |
|-----------|----------|-----------|----------|
| High byte | Low byte | High byte | Low byte |

#### 6.6 Register structure

The controller features 4 working registers, which can be addressed in a bitwise, byte-wise, word-by-word or double word fashion. In this context, it should be noted that byte/word addressing always addresses the LOWbyte/word.

#### Working registers A, B, C, D

| 31 | 24        | 23 10    | 6 15 8    | 37 0     |
|----|-----------|----------|-----------|----------|
|    | High      | word     | Low       | word     |
|    | High byte | Low byte | High byte | Low byte |

For operations that exceed the 32-bit format, the registers are combined to form permanent register pairs.

#### Working register pair A + B

| 31 | 24 23                | 16 15 | 87                  | 0 |
|----|----------------------|-------|---------------------|---|
|    | Word 4 = HIGH word B |       | Word 3 = LOW word B |   |
|    | Word 2 = HIGH word A |       | Word 1 = LOW word A |   |

#### Working register pair C + D

| 31 | 24 23                | 16 15 | 87                  | 0 |
|----|----------------------|-------|---------------------|---|
|    | Word 4 = HIGH word D |       | Word 3 = LOW word D |   |
|    | Word 2 = HIGH word C |       | Word 1 = LOW word C |   |

#### Status bits



## 6.7 Representation of constants

| Data type                    |                                                                               | PLC service program WinSPS                                                                                                               |  |
|------------------------------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|
| Description Representation   |                                                                               |                                                                                                                                          |  |
| UINT (unsigned integer)      | Binary / dual, word                                                           | 2#0000000_00000000 to 2#11111111_1111111                                                                                                 |  |
|                              | Decimal, wordDouble word                                                      | 0 to 655350<br>0 to 4294967295                                                                                                           |  |
|                              | Hexadecimal, wordDouble word                                                  | 16#0000 to 16#FFFF<br>16#00000000 to 16#FFFFFFFF                                                                                         |  |
| INT (signed integer)         | Decimal, wordDouble word                                                      | -32768 to +32767<br>-2147483648 to +2147483647                                                                                           |  |
| Floating point REAL<br>LREAL | Double word<br>Quadword                                                       | 1.175494351e <sup>-38</sup> to 3.402823466e <sup>+38</sup><br>2.2250738585072014e <sup>-308</sup> to 1.7976931348623158e <sup>+308</sup> |  |
| Text, STRING(2)              | ASCII, word double word                                                       | 'AB'<br>'ABCD'                                                                                                                           |  |
| Time value TVALUE            | Time value (+time base<br>r)r:<br>0 = 10 ms, 1 = 100 ms,<br>2 = 1 s, 3 = 10 s | T#10 ms to T#10230 s<br>T#0.r to T#1023.r                                                                                                |  |
| TCP/IP addresses, ISTRING    | Double word                                                                   | "1.2.3.4"                                                                                                                                |  |

## 6.8 Program module calls

|                                            | PLC service pro | gram WinSPS |
|--------------------------------------------|-----------------|-------------|
| Program module / function call (IEC1131/3) | СМ              | PM          |

## 6.9 Jump instructions

|                  | PLC service program WinSPS |       |
|------------------|----------------------------|-------|
| Jump instruction | JPx                        | label |
| Jump destination | label                      |       |

#### 6.10 Bit- and module addresses

| Operand | Addresses (decimal) |
|---------|---------------------|
| 1       | 0.0 to 8191.7       |
| 0       | 0.0 to 8191.7       |
| Μ       | 0.0 to 8191.7       |
| SM      | 0.0 to 31.7         |
| D       | 0.0 to 511.7        |
| DX      | 0.0 to 511.7        |
| DM      | 0.0 to 511.7        |
| DF      | 0.0 to 32767.7      |
| T-state | 0 to 256            |
| Z-state | 0 to 256            |
| Р       | 0 to 62             |
| DM      | 0 to 1023           |
| РМ      | 0 to 1023           |

### 6.11 Byte addresses

| Operand                | Address (decimal)    | Comment                                                                                                                                             |
|------------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 1                      | 0 to 8191            |                                                                                                                                                     |
| 0                      | 0 to 8191            |                                                                                                                                                     |
| T-act. val.<br>T-state | 0 to 256<br>0 to 256 | Timer range 10 ms to 1023 s; (Matrix: 0.01; 0.1; 1; 10 s)                                                                                           |
| Z-act. val.<br>Z-state | 0 to 256<br>0 to 256 | Counter range: 0 to 8191                                                                                                                            |
| М                      | 0 to 8191            |                                                                                                                                                     |
| S                      | 0 to 511             | <ul> <li>Managed values:</li> <li>System clock</li> <li>Error codes</li> <li>Times of time-controlled processing</li> <li>Versions, etc.</li> </ul> |
| Р                      | 0 to 62              |                                                                                                                                                     |
| DF                     | 0 to 32767           |                                                                                                                                                     |
| DM                     | 0 to 511             |                                                                                                                                                     |
| D                      | 0 to 511             |                                                                                                                                                     |
| DX                     | 0 to 511             |                                                                                                                                                     |

The even-numbered byte addresses are used as word addresses. For double word addresses the byte addresses have to be divisible by four.

#### 6.12 Addressing modes

#### 6.12.1 Absolute addressable operands

| reading<br>Byte, word, double word,<br>REAL, LREAL        | E, A, M, T, Z and P<br>const., DF, DP, D, DX,<br>SM, S | for T/C, actual values<br>apply          |
|-----------------------------------------------------------|--------------------------------------------------------|------------------------------------------|
| <b>writing</b> :<br>Byte,word,double word,<br>REAL, LREAL | A, M, P, DF, DP, D, DX, S                              | P writing, depending on assigned operand |

#### 6.12.2 Direct addressing of all absolute addressable operands



#### 6.12.3 Register-to-register addressing



#### Example:

```
L W C,B ; Load the contents of the low word
; of register C
; into the low word of
; register B
```

Examples

# 6.12.4 Register indirect addressing



### $\ensuremath{\mathbb{I}}\xspace^{-1}$ When employed as index register 32 bits are always used.

## 6.12.5 iPCL indirect addressing

Indirect addressing, whether word/byte or bit-oriented, is accomplished with the use of an operand prefix containing the operand identifier (operand ID) and operand address. This greatly facilitates the handling and monitoring of operand addresses.

In addition, all data and program modules can be called indirectly.

The operand prefix is structured as follows:

IF When loading index addresses into one of the registers, double word D must always be used as a supplement because the registers are 32 bits wide, and the HIGH word must be deleted!

Principle of indirect addressing, using the example of a block transfer via program loop:

Task to be accomplished:

Transfer of 5 input words starting at address I10 into marker words from address M50 upward.

| L    | W    | 5,A      | ; Load the loop counter          |  |  |  |  |
|------|------|----------|----------------------------------|--|--|--|--|
| L    | D    | 10,B     | ; Load the base byte address I10 |  |  |  |  |
| L    | D    | 50,C     | ; Load the base byte address M50 |  |  |  |  |
| Cont | inue | :        | ; Loop entry label               |  |  |  |  |
| L    | W    | E[B],D   | ; Load contents                  |  |  |  |  |
|      |      |          | ; (Operand state)                |  |  |  |  |
| Т    | W    | D,M[C]   | ; Write state that was loaded    |  |  |  |  |
| INC  | D    | В,2      | ; Next I-word (byte addr. + 2)   |  |  |  |  |
| INC  | D    | С,2      | ; Next M-word                    |  |  |  |  |
| DEC  | D    | A,1      | ; Loop counter -1                |  |  |  |  |
| SPN  |      | continue | ; Not all words processed yet    |  |  |  |  |

#### Indirect byte addresses

| OPD-ID      | Byte address<br>(dec.) | Instructions<br>[Reg] | Examples     |
|-------------|------------------------|-----------------------|--------------|
| I           | 0 to 8191              | L                     | L D 10,A     |
| 0           | 0 to 8191              | L, T                  | L W OPD[A],B |
| T-act. val. | 0 to 255               | L                     |              |
| Z-act. val. | 0 to 255               | L                     | L D 10,A     |
| Μ           | 0 to 8191              | L, T                  | T W B,OPD[A] |
| Р           | 0 to 62                | L                     |              |
| S           | 0 to 511               | L, T                  |              |
| SM          | 0 to 31                | L, T                  |              |
| DF          | 0 to 32767             | L, T                  |              |
| DM          | 0 to 511               | L, T                  |              |
| D           | 0 to 511               | L, T                  |              |
| DX          | 0 to 511               | L, T                  |              |

In order to address the next byte or next T/C the address needs to be incremented by 1. In order to address the next word the address needs to be incremented by 2.

### Indirect bit addresses

| OPD-ID  | Byte ad-<br>dress (dec.) | Instructions          | For examples of OPD see column 1 |
|---------|--------------------------|-----------------------|----------------------------------|
| 1       | 0 to 65455               | A, AN, O, ON          |                                  |
| 0       | 0 to 65455               | A, AN, O, ON, S, R, = | L D 10,AU OPD[A]                 |
| М       | 0 to 65455               | A, AN, O, ON, S, R, = | = OPD[A]                         |
| S       | 0 to 4095                | A, AN, O, ON          |                                  |
| SM      | 0 to 255                 | A, AN, O, ON          |                                  |
| D       | 0 to 4095                | A, AN, O, ON, S, R, = |                                  |
| DX      | 0 to 4095                | A, AN, O, ON, S, R, = |                                  |
| DM      | 0 to 4095                | A, AN, O, ON, S, R, = |                                  |
| DF      | 0 to 262143              | A, AN, O, ON, S, R, = |                                  |
| T-state | 0 to 255                 | A, AN, O, ON          |                                  |
| Z-state | 0 to 255                 | A, AN, O, ON          |                                  |

To address the next bit relative to a given starting address, this address must be incremented by 1.

#### Indirect module addresses

| Operand | Module number | Instructions<br>[Reg] | Example   |
|---------|---------------|-----------------------|-----------|
| DM      | 0 to 1023     | CMx                   | L D 10,A  |
|         |               | BXx                   | CM DM[A]  |
| PM      | 0 to 1023     | CMx                   | L D 100,A |
|         |               | CMx                   | CM PM[A]  |

To address the next module relative to a given module number, it must be incremented by 1.

In the case of a range violation or if the module is not available, the controller will enter STOP mode. In both instances, the cause of the error can be indicated by the Programming Unit (PG).

## 6.13 Parameter transfer

When a program module is called up, up to 63 parameters can be transferred. The number of parameters transferred is specified in the module call-up command. Then the parameters follow, starting with P0. In a PM that has been called, these parameters can also be processed indirectly: (L D P[R],R).

# IF The indirect processing of parameters is only possible from WinSPS version 3.0 onwards.

The applicable operand attributes are listed below:

- D double word (default)
- W word
- B-byte

Bit operands are programmed without the use of attributes.

#### □ Timers and counters are transferred without operand attributes to facilitate their use as both word (i.e. timer / counter values) and as bit (i.e. timer / counter status) in the module to be called.

Example: Parameter transfer

| CM<br>P0<br>P1<br>P2<br>P3<br>P4<br>P5<br>P6 | D<br>D<br>W | PM100,7<br>43<br>4<br>056<br>I7.3<br>T2<br>C13<br>010.0 | ; Call PM100 using 7 parameters<br>;Parameter P0: PM no. as constant 43<br>;Parameter P1: DM no. as constant K4<br>;Parameter P2: Ouput word at byte addr. O56<br>;Parameter P3: Input bit I7.3<br>;Parameter P4: Timer T2<br>;Parameter P5: Counter C13<br>;Parameter P6: Output bit O10.0 |
|----------------------------------------------|-------------|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                              | Ŭ           | Itilization of                                          | parameters in called-up module PM100:                                                                                                                                                                                                                                                       |
| L<br>CM<br>BX                                | D           | P1,A<br>DM[A]<br>-DB5                                   | ;Load data module no. 4<br>;Open DM4                                                                                                                                                                                                                                                        |
| L<br>CM                                      | D           | P0,A<br>PB[A]0.2                                        | ;Load PM no. 43<br>;Use 2 parameters to call PM43                                                                                                                                                                                                                                           |
| P0                                           | D           | 43                                                      | ;Parameter PO: D2 of active 1st DM (DM4)                                                                                                                                                                                                                                                    |
| P1                                           | D           | 4                                                       | ;Parameter P1: DX6 of active 2nd DM (DM5)                                                                                                                                                                                                                                                   |
| L                                            | W           | P2,A                                                    | ;Load output word 056                                                                                                                                                                                                                                                                       |
| L                                            | W           | P4,B                                                    | ;Load timer value from T2 to B                                                                                                                                                                                                                                                              |
| U                                            |             | Р3                                                      | ;E7.3                                                                                                                                                                                                                                                                                       |
| A                                            |             | P4                                                      | ;Status of T2                                                                                                                                                                                                                                                                               |
| A                                            |             | P5                                                      | ;Status of C13                                                                                                                                                                                                                                                                              |
| =                                            |             | P6                                                      | ;010.0                                                                                                                                                                                                                                                                                      |

# 6.14 Addressing limits

#### **Direct addressing**

In direct addressing, addressing limits are determined by the operand attribute.

| Byte        | Address as desired     |
|-------------|------------------------|
| Word        | Address even-numbered  |
| Double word | Address divisible by 4 |
| REAL        | Address divisible by 4 |
| LREAL       | Address divisible by 8 |

### Example:

| Operand | в | w | D | R | L |
|---------|---|---|---|---|---|
| MO      | х | x | х | x | x |
| M1      | х |   |   |   |   |
| M2      | х | x |   |   |   |
| M3      | х |   |   |   |   |
| M4      | х | x | х | x |   |
| M5      | х |   |   |   |   |
| M6      | х | x |   |   |   |
| M7      | х |   |   |   |   |
| M8      | х | x | х | x | x |

#### Indirect addressing

#### Example:

| L D   | 0,A    | ;Address byte 0               |  |  |  |  |
|-------|--------|-------------------------------|--|--|--|--|
| L D   | M[A],B | ;State of M0+M1+M2+M3 is read |  |  |  |  |
| INC D | A,1    | ;Address byte 1               |  |  |  |  |
| L D   | M[A],B | ;State of M1+M2+M3+M4 is read |  |  |  |  |
| INC D | A,1    | ;Address byte 2               |  |  |  |  |
| L D   | M[A],B | ;State of M2+M3+M4+M5 is read |  |  |  |  |
| INC D | A,1    | ;Address byte 3               |  |  |  |  |
| L D   | M[A],B | ;State of M3+M4+M5+M6 is read |  |  |  |  |
| INC D | A,1    | ;Address byte 4               |  |  |  |  |
| L D   | M[A],B | ;State of M4+M5+M6+M7 is read |  |  |  |  |

### Parameterized addressing

Parameterized addressing is not subject to the same addressing limits as indirect addressing.

#### Example:

| Parar | neter definition | Parameter query |   |      | Reads the following: |
|-------|------------------|-----------------|---|------|----------------------|
| P0    | M1               | L               | В | P0,A | M1                   |
| P1    | МЗ               | L               | W | P1,A | M3 and M4            |
| P2    | M5               | L               | D | P2,A | M5 to M8             |
| P3    | M7               | L               | D | P3,A | M7 to M10            |
| P1    | M11              | L               | L | P1,A | M11 to M18           |

Notes:

# 7 Instruction set

# 7.1 Structure of controller instructions

| Controller in      | Line comment      |                |    |                         |                           |
|--------------------|-------------------|----------------|----|-------------------------|---------------------------|
| Operations<br>part | Operand attribute | Source operand |    | Destinatio<br>n operand | ]                         |
| OPP                | OPA               | SRC            | ,[ | DEST                    | ; Instruction description |
| Examples:          |                   |                |    |                         |                           |
| U                  |                   | I0.0           |    |                         |                           |
| U                  | W                 | -Name          | ,  | 0                       |                           |
| L                  | В                 | 00             | ,  | В                       |                           |
| Т                  | D                 | С              | ,  | M12                     |                           |
| MUL                | W                 | 1234           | ,  | D                       |                           |

# 7.2 Flags

The flags are influenced by the following instruction groups:

| • | Bit instructions |
|---|------------------|
| • | Compare          |
| • | Convert          |

- ......
- Swap
  - Increment
- Decrement

- Shift
- Rotate
- Add
- Subtract
- Multiply
- Divide

They can be used not only in program processing instructions (jumps, module instructions) but also in logical links (special marker queries).

| Flags | Display in<br>WinSPS | JP<br>CM | Flag    | g query | Description          |
|-------|----------------------|----------|---------|---------|----------------------|
| CY=1  | С                    | C        | U       | CY      | Carry                |
| CY=0  |                      | CN       | AN      | CY      | Carry Not            |
| O=1   | 0                    | 0        | U       | 0       | OverflowOverflow     |
| O=0   |                      | ON       | AN      | 0       | not                  |
| Z=1   | Z                    | Z        | U       | Z       | Zero                 |
| Z=0   |                      | N        | AN      | Z       | Not Zero             |
| N=1   | N                    | M        | U       | Ν       | Negative/minus       |
| N=0   |                      | P        | AN      | Ν       | Positive             |
| AG=1  |                      | AG       | No flag | link    | Arithmetical greater |
| AG=0  | N v Z                | MZ       | U       | Z       | Minus / zero         |
|       |                      |          | 0       | Ν       |                      |
|       |                      |          | AN      | 0       |                      |
|       |                      |          | ON      | Ν       |                      |
|       |                      |          | U       | 0       |                      |
| LG=1  |                      | LG       | AN      | Z       | Logical greater      |
|       |                      |          | AN      | CY      |                      |
| LG=0  | CvZ                  | CZ       | U       | Z       | Carry/zero           |
|       |                      |          | 0       | CY      |                      |

# 7.3 Key to abbreviations

| OPP   |        | Operation                                              |
|-------|--------|--------------------------------------------------------|
| OPA   |        | Operand attribute                                      |
|       | В      | Byte                                                   |
|       | W      | Word                                                   |
|       | D      | Double word                                            |
|       | R      | REAL                                                   |
|       | L      | LREAL (LongReal)                                       |
| SRC   |        | Source operand                                         |
| DEST  |        | Destination operand                                    |
|       | I      | Input                                                  |
|       | 0      | Output                                                 |
|       | М      | Markers                                                |
|       | К      | Constants                                              |
|       | SM     | Special marker                                         |
|       | т      | Timer                                                  |
|       | Z      | Counters                                               |
|       | D      | Data word (within data modules)                        |
|       | DM     | Data buffer                                            |
|       | DF     | Data field                                             |
|       | S      | System area                                            |
|       | DM     | Data module                                            |
|       | DX     | 2. 2nd active data module                              |
|       | РМ     | Program module                                         |
|       | SYM    | Symbolic                                               |
|       | R.bit  | Register bit with $R = A, B, C, D$ , and bit = 0 to 31 |
|       | OPD[R] | Register indirect with operand prefix                  |
|       | ті     | Time interrupt (time-controlled processing)            |
| RG    |        | Program branch                                         |
|       | Α      | Operation permitted at RG beginning                    |
|       | E      | Operation concluding RG                                |
| Addr. |        | Addressing mode                                        |
|       | D      | Direct                                                 |
|       | R      | Register A, B, C, or D                                 |
|       | [R]    | Register indirect with operand prefix                  |
| Flag  |        | State bit                                              |
|       | V      | Link result RES                                        |
|       | CY     | Carry                                                  |
|       | 0      | Overflow                                               |
|       | Z      | Zero                                                   |
|       | Ν      | Negative                                               |

# 7.4 Bit instructions

Bit instructions modify the state bits C, Z, O, and N.

### **Exception:** Flags themselves are not changed by a binary flag query.

Links are interpreted in accordance with the Boolean "AND" before "OR" logic principle. Parenthesized instructions are used to form logical intermediate results.

| C   | Contro | oller instruct | ion   | F | ß | Α | ddr. t | уре |   |    | Flag |   |   | Ex | ample   | Comment                   |
|-----|--------|----------------|-------|---|---|---|--------|-----|---|----|------|---|---|----|---------|---------------------------|
| OPP | OPA    | SRC            | Z-OPD | А | Е | D | R      | [R] | v | CY | 0    | Ν | z |    |         |                           |
| U   |        | I/O/M/SM       |       | • |   | • |        |     | • | •  | •    |   | • | U  | 10.0    | AND link, query status 1  |
|     |        | T/C/SYM        |       | • |   | • |        |     | • | •  | •    |   | • | U  | T0      |                           |
|     |        | R.bit          |       | • |   |   | •      |     | • | •  | •    |   | • | U  | A.0     |                           |
|     |        | OPD[R]         |       | • |   |   |        | •   | • | •  | •    |   | • | U  | M[A]    |                           |
|     |        | Р              |       | • |   | • |        |     | • | •  | •    |   | • | U  | P0      |                           |
|     |        | S/D/DX/DF/DP   |       | • |   | • |        |     | • | •  | •    |   | • | U  | D0.0    |                           |
|     |        | CY/Z/O/N       |       | • |   | • |        |     |   |    |      |   |   | U  | CY      |                           |
| AN  |        | I/O/M/SM       |       | • |   | • |        |     | • | •  | •    |   | • | AN | A0.0    | AND link, query status 0  |
|     |        | T/C/SYM        |       | • |   | • |        |     | • | •  | •    |   | • | AN | Z0      |                           |
|     |        | R.bit          |       | • |   |   | •      |     | • | •  | •    |   | • | AN | B0.0    |                           |
|     |        | OPD[R]         |       | • |   |   |        | •   | • | •  | •    |   | • | AN | M[B]    |                           |
|     |        | Р              |       | • |   | • |        |     | • | •  | •    |   | • | AN | P1      |                           |
|     |        | S/D/DX/DF/DP   |       | • |   | • |        |     | • | •  | •    |   | • | AN | D0.0    |                           |
|     |        | CY/Z/O/N       |       | • |   | • |        |     |   |    |      |   |   | AN | CY      |                           |
| 0   |        | I/O/M/SM       |       | • |   | • |        |     | • | •  | •    |   | • | 0  | M0.0    | OR link, query status 1   |
|     |        | T/C/SYM        |       | • |   | • |        |     | • | •  | •    |   | • | 0  | -SYMBOL |                           |
|     |        | R.bit          |       | • |   |   | •      |     | • | •  | •    |   | • | 0  | C0.0    |                           |
|     |        | OPD[R]         |       | • |   |   |        | •   | • | •  | •    |   | • | 0  | MD[C]   |                           |
|     |        | Р              |       | • |   | • |        |     | • | •  | •    |   | • | 0  | P10     |                           |
|     |        | S/D/DX/DF/DP   |       | • |   | • |        |     | • | •  | •    |   | • | 0  | D0.0    |                           |
|     |        | CY/Z/O/N       |       | • |   | • |        |     |   |    |      |   |   | 0  | CY      |                           |
| ON  |        | I/O/M/SM       |       | • |   | • |        |     | • | •  | •    |   | • | ON | SM31.7  | OR link, query status 0   |
|     |        | T/C/SYM        |       | • |   | • |        |     | • | •  | •    |   | • | ON | Name    |                           |
|     |        | R.bit          |       | • |   |   | •      |     | • | •  | •    |   | • | ON | D.0     |                           |
|     |        | OPD[R]         |       | • |   |   |        | •   | • | •  | •    |   | • | ON | M[D]    |                           |
|     |        | Р              |       | • |   | • |        |     | • | •  | •    |   | • | ON | P62     |                           |
|     |        | S/D/DX/DF/DP   |       | • |   | • |        |     | • | •  | •    |   | • | ON | D0.0    |                           |
|     |        | CY/Z/O/N       |       | • |   | • |        |     |   |    |      |   |   | ON | CY      |                           |
| =   |        | A/M/SYM        |       |   | • | • |        |     | • | •  | •    |   | • | =  | A0.0    | Assign result when        |
|     |        | S/D/DX/DF/DP   |       |   | • | • |        |     | • | •  | •    |   | • | =  | D0.0    | RES = 1                   |
|     |        | Р              |       |   | • | • | •      |     | • | •  | •    |   | • | =  | P0      |                           |
|     |        | OPD[R]         |       |   | • |   |        | •   | • | •  | •    |   | • | =  | M[A]    |                           |
|     |        | R.bit          |       |   | • |   | •      |     | • | •  | •    |   | • | =  | A.0     |                           |
| S   |        | A/M/SYM        |       |   | • | • |        |     | • | •  | •    |   | • | S  | M0.0    | Set bit HIGH when RES = 1 |
|     |        | S/D/DX/DF/DP   |       |   | • | • |        |     | • | •  | •    |   | • | S  | D0.0    |                           |
|     |        | Р              |       |   | • | • | •      |     | • | •  | •    |   | • | S  | P1      |                           |
|     |        | OPD[R]         |       |   | • |   |        | •   | • | •  | •    |   | • | S  | M[B]    |                           |
|     |        | R.bit          |       |   | • |   | •      |     | • | •  | •    |   | • | S  | B0.0    |                           |

| OPP | OPA | SRC          | Z-OPD | А | Е | D | R | [R] | V | CY | 0 | Ν | Z |    |         |                                   |
|-----|-----|--------------|-------|---|---|---|---|-----|---|----|---|---|---|----|---------|-----------------------------------|
| R   |     | A/M/SYM      |       |   | • | • |   |     | • | •  | • |   | • | R  | -SYMBOL | Set bit LOW when RES = 1          |
|     |     | S/D/DX/DF/DP |       |   | • | • |   |     | • | •  | • |   | • | R  | D0.0    |                                   |
|     |     | Р            |       |   | • | • | • |     | • | •  | • |   | • | R  | P62     |                                   |
|     |     | OPD[R]       |       |   | • |   |   | •   | • | •  | • |   | • | R  | M[C]    |                                   |
|     |     | R.bit        |       |   | • |   | • |     | • | •  | • |   | • | R  | C0.0    |                                   |
| Р   |     | R.bit        |       |   |   |   | • |     | • | •  | • |   | • | Р  | A.0     | Check register bit for status = 1 |
|     |     |              |       |   |   |   |   |     |   |    |   |   |   |    |         | if met: C = 1                     |
| PN  |     | R.bit        |       |   |   |   | • |     | • | •  | • |   | • | Р  | A.15    | Check register bit for status = 0 |
|     |     |              |       |   |   |   |   |     |   |    |   |   |   |    |         | if met: C = 1                     |
| (   |     |              |       |   |   |   |   |     | • | •  | • |   | • | (  |         | AND opening bracket               |
| )   |     |              |       |   |   |   |   |     | • | •  | • |   | • | )  |         | Closing bracket                   |
| О(  |     |              |       |   |   |   |   |     | • | •  | • |   | • | 0( |         | OR opening bracket                |
| )N  |     |              |       |   |   |   |   |     | • | •  | • |   | • | )N |         | Negation of bracket contents      |

# 7.5 Timer programming

The iPCL provides 256 timer circuits, T0 through T255.

These can be used in the following modes:

- SP Pulse
- SPE Start pulse extended
- SR Start time as raising delay
- SF Start time as falling delay
- SRE Start time as raising delay extended

| Starting the non-residual starting timers SP, SPE, SR and SRE requires a                                                                                                                                                                                                                                                    |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| positive transition of the timer start condition. However, they are also started<br>if at the time of first addressing (1st PLC cycle) after startup or restart the<br>start condition equals 1.                                                                                                                            |
|                                                                                                                                                                                                                                                                                                                             |
| In the case of residual timers, the flank marker is retained, i.e. whether a 1 will start the timer at the time of first addressing (1st PLC cycle) after startup or restart, depends on the start condition prior to STOP or Power-OFF.                                                                                    |
|                                                                                                                                                                                                                                                                                                                             |
| In the case of the start time as falling delay, a "0" will not start the timer during the initial processing. Predefining the timer start condition with 1 is possible as early as in the startup OM, provided that the information about residual characteristics (see Section on Residual characteristics) is considered. |
| The timers are decremented in the I/O state. A timeout is thus recognized only in the I/O state, and not during the program cycle!                                                                                                                                                                                          |
| Because a timer is decremented in the I/O state by a multiple of the declared time matrix, it is useful to select a time matrix that is a small as possible.                                                                                                                                                                |
| The timer starts immediately upon a positive transition of the timer start condition.                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                                                             |

## 7.5.1 Timer instructions

Timer starts are activated only when the RES signal undergoes a transition from  $0 \uparrow 1$ . In advance of the timer start, the time value is loaded into the register being used. Reset and stop functions of timers are always RES signal-dependent. The timer status for logical links is instruction-dependent, and may be taken from the timer diagrams.

| C   | ontrol | ler instru             | iction                         |   | RG |   | Addr | -   |   |    | Flag |   |   | E                        | xample                              | Comment                                                     |
|-----|--------|------------------------|--------------------------------|---|----|---|------|-----|---|----|------|---|---|--------------------------|-------------------------------------|-------------------------------------------------------------|
| OPP | OPA    | SRC                    | Z-OPD                          | А | Е  | D | R    | [R] | v | CY | 0    | Ν | z |                          |                                     |                                                             |
| SP  |        | R                      | , Tn<br>, SYM<br>, T[R]<br>, P |   | •  | • |      | •   |   |    |      |   |   | SP<br>SP<br>SP<br>SP     | A,T0<br>A,-Symbol<br>A,T[B]<br>A,P0 | Pulse                                                       |
| SPE |        | R                      | , Tn<br>, SYM<br>, T[R]<br>, P |   | •  | • |      | •   |   |    |      |   |   | SPE<br>SPE<br>SPE<br>SPE | A,T0<br>A,-Symbol<br>A,T[B]<br>A,P0 | Start pulse extended                                        |
| SR  |        | R                      | , Tn<br>, SYM<br>, T[R]<br>, P |   | •  | • |      | •   |   |    |      |   |   | SR<br>SR<br>SR<br>SR     | A,T0<br>A,-Symbol<br>A,T[B]<br>A,P0 | On-delay                                                    |
| SF  |        | R                      | , Tn<br>, SYM<br>, T[R]<br>, P |   | •  | • |      | •   |   |    |      |   |   | SF<br>SF<br>SF<br>SF     | A,T0<br>A,-Symbol<br>A,T[B]<br>A,P0 | Off-delay                                                   |
| SRE |        | R                      | , Tn<br>, SYM<br>, T[R]<br>, P |   | •  | • |      | •   |   |    |      |   |   | SRE<br>SRE<br>SRE<br>SRE | A,T0<br>A,-Symbol<br>A,T[B]<br>A,P0 | Start time as raising delay extended                        |
| RT  |        | Tn<br>SYM<br>T[R]<br>P |                                |   | •  | • |      | •   |   |    |      |   |   | RT<br>RT<br>RT<br>RT     | T0<br>-Symbol<br>T[B]<br>P0         | Set timer LOW when RES = 1                                  |
| TH  |        | Tn<br>SYM<br>T[R]<br>P |                                |   | •  | • |      | •   |   |    |      |   |   | TH<br>TH<br>TH<br>TH     | T0<br>-Symbol<br>T[B]<br>P0         | Timer STOP when RES = 1,<br>timer continues when RES =<br>0 |

## 7.5.2 Time format

| 15 | 14 | 13 | 12 | 11          | 10 | 9                                           | 8    | 7   | 6                         | 5      | 4  | 3              | 2 | 1      | 0 |
|----|----|----|----|-------------|----|---------------------------------------------|------|-----|---------------------------|--------|----|----------------|---|--------|---|
| х  | х  | х  | х  | R           | R  | W                                           | W    | W   | W                         | W      | W  | W              | W | W      | W |
|    |    |    |    | Time<br>mat |    | Tim<br>valu                                 |      | 1 – | 1023                      |        |    |                |   |        |   |
|    |    |    |    | 0           | 0  | 0: 1                                        | 0 ms | 6   |                           |        |    |                |   |        |   |
|    |    |    |    | 0           | 1  | 1: 1                                        | 00 m | e   | Progra<br>entry<br>consta | of tim | ne |                |   |        |   |
|    |    |    |    | 1           | 0  | 0 2: 1 s w.r with time value<br>w = 1 -1023 |      |     |                           |        |    |                |   |        |   |
|    |    |    |    | 1           | 1  | 3: 1                                        | 0 s  |     |                           |        | -  | nd ti<br>= 0 - |   | natrix |   |

The following applies to the time format:

### Example:

Timer T100 is to be started at 15 sec:

L W T#15s,A ;15s declaration in the CL500 1s time matrix U B -start SPE A,T100

#### Same function but with smaller time matrix, i.e. higher accuracy:

L W T#15000ms,A ;15s declaration in the CL500 100ms time matrix U B -start SPE A,T100

#### Timer start with the assistance of the PG time matrix:

L W T#15.2,A ;15s declaration in the PG 1s time matrix U B -start SPE A,T100

#### Same function but with smaller time matrix, i.e. higher accuracy:

| L   | W | T#150.1,A | ;15s | declaration | in | the | $\mathbf{PG}$ | 100ms | time | matrix |
|-----|---|-----------|------|-------------|----|-----|---------------|-------|------|--------|
| U   | В | -start    |      |             |    |     |               |       |      |        |
| SPE |   | A,T100    |      |             |    |     |               |       |      |        |

# 7.5.3 Timer diagrams

| SP – Start time as | s pulse                 |                                                         |                      |
|--------------------|-------------------------|---------------------------------------------------------|----------------------|
|                    | Start conditions        |                                                         |                      |
|                    | Reset conditions        |                                                         |                      |
|                    | Timer status            | ← t →                                                   |                      |
| SPE – Start pulse  | extended                |                                                         |                      |
|                    | Start conditions        |                                                         |                      |
|                    | Reset conditions        |                                                         |                      |
|                    | Timer status            | $- \leftarrow t \rightarrow - \leftarrow t \rightarrow$ |                      |
| SR – Start time a  | s raising delay         |                                                         |                      |
|                    | Start conditions        |                                                         |                      |
|                    | Reset conditions        |                                                         |                      |
|                    | Timer status            | ← t →                                                   | (← <t→< th=""></t→<> |
| SF – Start time as | s falling delay         |                                                         |                      |
|                    | Start conditions        |                                                         |                      |
|                    | Reset conditions        |                                                         |                      |
|                    | Timer status            | ← t →                                                   | . ← t →              |
| SRE – Start time   | as raising delay extend | ded                                                     |                      |
|                    | Start conditions        |                                                         |                      |
|                    | Reset conditions        |                                                         |                      |
|                    | Timer status            |                                                         |                      |

## 7.6 Counter instructions

The setting of counters and counting up and down occurs only when the RES signal undergoes a transition from  $0 \rightarrow 1$ .

In advance of the setting, the required counter content is loaded into the register being used.

Counter resetting always occurs static RES signal-dependent.

The counter status for logical links depends on the counter content.

- For counter values > 0 the status = 1
- For value = 0 status = 0

The counting range is between 0 to 8191.

| Со  | ntrolle | er instru              | ction                          | F | RG |   | Add | r.  |   |    | Flag | Ļ |   | E                    | xample                              | Comment                      |
|-----|---------|------------------------|--------------------------------|---|----|---|-----|-----|---|----|------|---|---|----------------------|-------------------------------------|------------------------------|
| OPP | OPA     | SRC                    | Z-OPD                          | А | Е  | D | R   | [R] | V | CY | 0    | Ν | Z |                      |                                     |                              |
| Zn  |         | R                      | , Zn<br>, SYM<br>, Z[R]<br>, P |   | •  | • |     | •   |   |    |      |   |   | SC<br>SC<br>SC<br>SC | A,Z0<br>A,-Symbol<br>A,Z[B]<br>A,P0 | Set counter HIGH             |
| CU  |         | Zn<br>SYM<br>Z[R]<br>P |                                |   | •  | • |     | •   |   |    |      |   |   | CU<br>CU<br>CU<br>CU | Z0<br>-Symbol<br>Z[B]<br>P0         | Count up                     |
| CD  |         | Zn<br>SYM<br>Z[R]<br>P |                                |   | •  | • |     | •   |   |    |      |   |   | CD<br>CD<br>CD<br>CD | Z0<br>-Symbol<br>Z[B]<br>P0         | Count down                   |
| RC  |         | Zn<br>SYM<br>Z[R]<br>P |                                |   | •  | • |     | •   |   |    |      |   |   | RC<br>RC<br>RC<br>RC | Z0<br>-Symbol<br>Z[B]<br>P0         | Set counter LOW when RES = 1 |

# 7.7 Digital links

| Co  | ontrol      | ler instruct                                                    | ion   | R | G |         | Addr |     |   |                                 | Flag                            |                  |                  | Examp                                          | ble                                                                                    | Comment                                                                                                   |
|-----|-------------|-----------------------------------------------------------------|-------|---|---|---------|------|-----|---|---------------------------------|---------------------------------|------------------|------------------|------------------------------------------------|----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|
| OPP | OPA         | SRC                                                             | Z-OPD | А | Е | D       | R    | [R] | v | CY                              | 0                               | Ν                | Z                |                                                |                                                                                        |                                                                                                           |
| U   | B<br>W<br>D | I/O/M/SM<br>T/C/K/SYM<br>S/DF/DP<br>D/DX<br>R<br>OPD[R]<br>P    | , R   |   |   | •       | •    | •   |   | 0<br>0<br>0<br>0<br>0<br>0<br>0 | 0<br>0<br>0<br>0<br>0<br>0<br>0 | •<br>•<br>•<br>• | •<br>•<br>•<br>• | U W T<br>U B S<br>U W D                        | I[B],C                                                                                 | Digital AND link<br>between source and destina-<br>tion.<br>The result is written to destina-<br>tion.    |
| AN  | B<br>W<br>D | I/O/M/SM<br>T/C/K/SYM<br>S/DF/DP<br>D/DX<br>R<br>OPD[R]<br>P    | , R   |   |   | • • • • | •    | •   |   | 0<br>0<br>0<br>0<br>0<br>0<br>0 | 0<br>0<br>0<br>0<br>0<br>0<br>0 | •<br>•<br>•<br>• | •<br>•<br>•<br>• | AN W T<br>AN B S<br>AN W D<br>AN W A<br>AN B M | 127,A<br>127,B<br>511,C<br>9510,D<br>,B<br>1[B],C<br>62,D                              | Digital AND NOT<br>link between<br>source and destination.<br>The result is written to destina-<br>tion.  |
| 0   | B<br>W<br>D | I/O/M/SM<br>T/C/K/SYM<br>S/DF/DP<br>D/DX<br>R<br>OPD[R]<br>P    | , R   |   |   | •       | •    | •   |   | 0<br>0<br>0<br>0<br>0<br>0<br>0 | 0<br>0<br>0<br>0<br>0<br>0<br>0 | •<br>•<br>•<br>• | •<br>•<br>•<br>• | O W T<br>O B S<br>O W D<br>O W A               | .,B<br>1[B],C                                                                          | Digital OR link<br>between source and<br>destination.<br>The result is written to destina-<br>tion.       |
| ON  | B<br>W<br>D | I/O/M/SM<br>T/C/K/SYM<br>S/DF/DP<br>D/DX<br>R<br>OPD[R]<br>P    | , R   |   |   | •       | •    | •   |   | 0<br>0<br>0<br>0<br>0<br>0<br>0 | 0<br>0<br>0<br>0<br>0<br>0<br>0 | •<br>•<br>•<br>• | •<br>•<br>•<br>• | ON W T<br>ON B S<br>ON W D<br>ON W A<br>ON B M | (127,A<br>(127,B<br>(511,C<br>(510,D<br>(510,D<br>(510,D<br>(510,D<br>(52,D)<br>(52,D) | Digital OR NOT<br>link between<br>source and destination.<br>The result is written to destina-<br>tion.   |
| XO  | B<br>W<br>D | I/O/M/SM<br>T/C/K/SYM<br>S/DF/DP<br>D/DX<br>R<br>OPD[R]<br>P    | , R   |   |   | • • • • | •    | •   |   | 0<br>0<br>0<br>0<br>0<br>0<br>0 | 0<br>0<br>0<br>0<br>0<br>0<br>0 | •<br>•<br>•<br>• | •<br>•<br>•<br>• | XO W T<br>XO B S<br>XO W D<br>XO W A           | .,B<br>1[B],C                                                                          | EXCLUSIVE OR<br>link between<br>source and destination.<br>The result is written to destina-<br>tion.     |
| XON | B<br>W<br>D | I/O/M/SM<br>T/C/K/SYM<br>S/DP/DF/DP<br>D/DX<br>R<br>OPD[R]<br>P | , R   |   |   | • • • • | •    | •   |   | 0<br>0<br>0<br>0<br>0<br>0<br>0 | 0<br>0<br>0<br>0<br>0<br>0<br>0 | •<br>•<br>•<br>• | • • • • • •      | XON W T<br>XON B S<br>XON W D<br>XON W A       | 1[B],C                                                                                 | EXCLUSIVE OR NOT<br>link between<br>source and destination.<br>The result is written to destina-<br>tion. |

# 7.8 SWAP instructions

| Co   | ntroll | er instruct | ion   | R | G |   | Addr |     |   | I  | -lag |   |   | Example              | Comment                                                            |
|------|--------|-------------|-------|---|---|---|------|-----|---|----|------|---|---|----------------------|--------------------------------------------------------------------|
| OPP  | OPA    | SRC         | Z-OPD | А | Е | D | R    | [R] | v | CY | 0    | Ν | z |                      |                                                                    |
| SWAP | W<br>D | R           |       |   |   |   | •    |     |   |    |      |   |   | SWAP W O<br>SWAP D O | Change in register<br>High byte « Low byte<br>High word « Low word |

## 7.9 Compare instruction

The universally applicable CPLA (Compare Logical and Arithmetical) instruction is available for Compare operations. This facilitates both logical and arithmetic compare operations.

For reasons of compatibility the purely logical CPL instruction was also implemented; it is used to map binary result queries also in special markers.

The logical compare operation regards the bytes, words, or double words to be compared as unsigned integers, i.e. as unsigned 8, unsigned 16, or unsigned 32.

The arithmetical compare operation regards the bytes, words, or double words to be compared as signed integers, i.e., as signed 8, signed 16, or signed 32.

| Co   | ntroll      | er instruct                                                  | tion  | R | G | Addr.       |   |     |   |                  |                  | Fla               | ŋg               |                  |                 | Ex                                                   | ample                                                                       | Comment                                                                                                                                                                           |
|------|-------------|--------------------------------------------------------------|-------|---|---|-------------|---|-----|---|------------------|------------------|-------------------|------------------|------------------|-----------------|------------------------------------------------------|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OPP  | ОРА         | SRC                                                          | Z-OPD | А | Е | D           | R | [R] | V | CY               | 0                | Ν                 | z                | AG               | LG              |                                                      |                                                                             |                                                                                                                                                                                   |
| CPLA | B<br>W<br>D | I/O/M/SM<br>T/C/K/SYM<br>S/DF<br>D/DX/DP<br>R<br>OPD[R]<br>P | , R   |   |   | •<br>•<br>• | • | •   |   | •<br>•<br>•<br>• | •<br>•<br>•<br>• | • • • • • • • • • | •<br>•<br>•<br>• | •<br>•<br>•<br>• | • • • • • • • • | CPLA<br>CPLA<br>CPLA<br>CPLA<br>CPLA<br>CPLA<br>CPLA | W E62,A<br>B 255,B<br>W DF510,C<br>B D511,D<br>B B,C<br>W M[C],D<br>B P62,A | Arithmetical compare function.<br>The result may be used for log-<br>ical and arithmetical purposes.<br>Compare vlues<br>Logical: positive, integer<br>arithm.: two's complement, |
| CPL  | B<br>W<br>D | I/O/M/SM<br>T/C/K/SYM<br>S/DF<br>D/DX/DP<br>R<br>OPD[R]<br>P | , R   |   |   | • • • •     | • | •   |   | • • • • •        | •<br>•<br>•<br>• | • • • • • •       | •<br>•<br>•<br>• | • • • • • •      | • • • • • •     | CPL<br>CPL<br>CPL<br>CPL<br>CPL<br>CPL<br>CPL        | W E62,A<br>B 255,B<br>W DF510,C<br>B D511,D<br>B B,C<br>W M[C],D<br>B P62,A | signed<br>Logical compare operation.<br>The result may be used for log-<br>ical purposes only,<br>i.e. the values will be treated<br>as positive integers.                        |

CPLA compare vlues:

- Logical: positive, integer
- Arithmetical: two's complement, signed integer

After a compare operation, the flags or special markers provide information about the result of the compare.

| Compare                  |                                                                                                      | CPL                   | B,A   |         | CPLA B,A              |          |         |                       |  |  |  |  |
|--------------------------|------------------------------------------------------------------------------------------------------|-----------------------|-------|---------|-----------------------|----------|---------|-----------------------|--|--|--|--|
| destination (A) w<br>(B) | lith source                                                                                          | Log                   | jical |         | Log                   | jical    |         | Arithmetical          |  |  |  |  |
|                          |                                                                                                      | Jump instruc-<br>tion | Fla   | g query | Jump instruc-<br>tion | Fla      | g query | Jump instruc-<br>tion |  |  |  |  |
| Equal                    | A=B                                                                                                  | JPZ                   | U     | SM31.7  | JPZ                   | U        | Z       | JPZ                   |  |  |  |  |
| Unequal                  | A≠B                                                                                                  | JPN                   | UN    | SM31.7  | JPN                   | UN       | Z       | JPN                   |  |  |  |  |
| Less than                | A <b< td=""><td>JPN</td><td>U</td><td>SM31.6</td><td>JPCY</td><td>U</td><td>CY</td><td>JPM</td></b<> | JPN                   | U     | SM31.6  | JPCY                  | U        | CY      | JPM                   |  |  |  |  |
| Less than /<br>equal     | A≤B                                                                                                  | JPCZ                  | UN    | SM31.0  | JPCZ                  | U<br>O   | Z<br>CY | JPMZ                  |  |  |  |  |
| Greater than             | A>B                                                                                                  | JPLG                  | U     | SM31.0  | JPLG                  | UN<br>UN | CY<br>Z | JPAG                  |  |  |  |  |
| Greater than / equal     | A≥B                                                                                                  | JPCN                  | UN    | SM31.6  | JPCN                  | UN       | CY      | SPP                   |  |  |  |  |

#### Examples:

- IF When using the CPLA instruction, the evaluation of the compare results must always be programmed immediately following the compare instruction itself. The user is advised to bear in mind that with the exception of flag queries, binary operations will cause a modification of the flags. Therefore, a compare result can be used only in a link. Following this, another CPLA instruction must again be programmed.
- □ The special markers that are influenced only by the CPL instruction will remain unaffected until the next CPL instruction.

## 7.10 Load instructions

Load instructions (L) are used to write statuses or values from operands into registers. Signal statuses of inputs / outputs are loaded from the periphery image.

In the event that the status of inputs or outputs is to be loaded directly from the peripherals during the program cycle, then this status must be loaded into the image (LD) before the actual load instruction (L) is issued.

| Co  | ontroll     | er instruct                                                                         | tion         | R | G |           | Addr. |     |   |    | Flag |   |   | Example                                                                                                     | Comment                                                                                                                                                                                                                                                  |
|-----|-------------|-------------------------------------------------------------------------------------|--------------|---|---|-----------|-------|-----|---|----|------|---|---|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OPP | OPA         | SRC                                                                                 | Z-OPD        | А | Е | D         | R     | [R] | V | CY | 0    | Ν | z |                                                                                                             |                                                                                                                                                                                                                                                          |
| L   | B<br>W<br>D | I/O/M/SM<br>T/C/K/SYM<br>DF/DP<br>D/DX<br>R<br>OPD[R]<br>P<br>P[R]<br>OM, FC,<br>DM | , R          |   |   | • • • • • | •     | •   |   |    |      |   |   | L W E0,A<br>L B 0,B<br>L W DF0,C<br>L B D0,D<br>L B B,C<br>L W M[C],D<br>L B P0,A<br>L D P[A],B<br>L DB10,A | Load content of SRC<br>into DEST. (Read I/O image)<br>Read value<br>Load DB10 module size                                                                                                                                                                |
| LD  |             | I<br>I[R]                                                                           | , К<br>, [R] |   |   | •         |       | •   |   |    |      |   |   | LD E0,20<br>LD E0,[B]<br>LD E[A],[B]                                                                        | Load 20 bytes* of input sta-<br>tuses into image, starting with<br>I0.<br>Load I-statuses into image,<br>starting with I0; byte* count in<br>B.<br>Load I-statuses into image<br>(start address in A), (byte*<br>count in B).<br>* max. byte count = 256 |

#### Example of direct loading:

| LD | D | I12,4 | ; Load byte from I12 from the bus master into I-image |
|----|---|-------|-------------------------------------------------------|
|    |   |       |                                                       |

- L D I12,4 ; Load statuses I12 through I15 into register A
- □ When using the "indirect parameter" load instruction (L D P[R],R), the WinSPS is unable to perform a syntax check because it cannot foresee which operand address will actually be addressed by the parameter. The controller may enter STOP mode. The user is therefore advised to ensure the required syntax for this instruction is used.

## 7.11 Tranfer instructions

Transfer instructions (T) are used to write statuses or values from registers to operands. Signal statuses from outputs are written into the periphery image. In the I/O state this image is then transferred to the outputs.

In the event that the statuses of outputs are to be sent directly to the peripherals during the program cycle, then the transfer instruction (TD) will be used.

| С   | ontro       | ller instru | uction                                                     | R | G | Addr. |   |     |   |    | Flag |   |   | Example                                                                | Comment                                                                                                             |
|-----|-------------|-------------|------------------------------------------------------------|---|---|-------|---|-----|---|----|------|---|---|------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| OPP | OPA         | SRC         | Z-OPD                                                      | А | Е | D     | R | [R] | v | CY | 0    | Ν | z |                                                                        |                                                                                                                     |
| Т   | B<br>W<br>D | R           | , A/M/SYM<br>, S/DF<br>, D/DX/DP<br>, R<br>, OPD[R]<br>, P |   |   | •     | • | •   |   |    |      |   |   | T W A,M0<br>T B B,DF0<br>T W C,D0<br>T W A,B<br>T B B,M[C]<br>T W D,P0 | Transfer content of SRC<br>to DEST. (Write I/O image)<br>Write value.                                               |
| TD  |             | 0<br>O[R]   | , K<br>, [R]                                               |   |   | •     |   | •   |   |    |      |   |   | TD 00,20<br>TD 00,[B]                                                  | Send 20 bytes* of output sta-<br>tuses from image to outputs,<br>starting with O0.<br>Send O-statuses from image to |
|     |             |             |                                                            |   |   |       |   |     |   |    |      |   |   | TD A[A],[B]                                                            | outputs, starting with O0. (Byte count* in B).<br>Send O-statuses from image to                                     |
|     |             |             |                                                            |   |   |       |   |     |   |    |      |   |   | t.n[0]                                                                 | outputs (start address in A).<br>(Byte count* in B).                                                                |
|     |             |             |                                                            |   |   |       |   |     |   |    |      |   |   |                                                                        | * max. byte count = 256                                                                                             |

#### Example of direct transfer:

| L  | D | 16#1234FFFF,A | ; Load hex constant into register A             |
|----|---|---------------|-------------------------------------------------|
| Т  | D | A,A12         | ; and write to O-image.                         |
| TD | D | A12,4         | ;transfer 4 bytes into bus master ;for A12-A15. |

# 7.12 Convert instructions

| Co  | ntrolle     | er instruc | ction | RG |   | Addr. |   |     |   |    | Flag |   |   | Exa | mple     | Comment                                                                                                                                              |
|-----|-------------|------------|-------|----|---|-------|---|-----|---|----|------|---|---|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| OPP | OPA         | SRC        | Z-OPD | А  | Е | D     | R | [R] | V | CY | 0    | Ν | Z |     |          |                                                                                                                                                      |
| BID | B<br>W<br>D | R          |       |    |   |       | • |     |   | 0  | •    | 0 | • |     | V O<br>B | $\begin{array}{l} \mbox{Binary} \rightarrow \mbox{BCD} \mbox{ (decimal)} \\ \mbox{result} > \mbox{9999 sets the} \\ \mbox{overflow bit} \end{array}$ |
| DEB | B<br>W<br>D | R          |       |    |   |       | • |     |   | 0  | •    | 0 | • |     | V C<br>D | $BCD$ (decimal) $\rightarrow$ Binary<br>wrong BCD coding<br>sets the overflow bit.                                                                   |
| CMP | B<br>W<br>D | R          |       |    |   |       | • |     |   | •  | •    | • | • |     | V O<br>B | Converts register contents to the two's complement.                                                                                                  |
| N   | B<br>W<br>D | R          |       |    |   |       | • |     |   | 0  | •    | 0 | • |     | V C<br>D | Negates register contents,<br>one's complement.                                                                                                      |

Positive and negative numbers are differentiated by the status of the MSB.

| OPA         | Positive   | Range               | Negative   | Range               |
|-------------|------------|---------------------|------------|---------------------|
| Double word | Bit 31 = 0 | 0 to +2,147,483,647 | Bit 31 = 1 | 0 to -2,147,483,648 |
| Word        | Bit 15 = 0 | 0 to +32,767        | Bit 15 = 1 | 0 to –32,768        |
| Byte        | Bit 7 = 0  | 0 to +127           | Bit 7 = 1  | 0 to -128           |

Example: The representation of positive and negative numbers.

By way of illustration, a 4-bit number (nibble) is used here; the nibble data format is not supported by the controller.

- 0110 positive number 6
- 1 0 0 1 negation one's complement

1

1010 two's complement = negative number 6



# 7.13 Increment & Decrement instructions

Increment / decrement the contents of source operand SRC:

- by the number n; (where n=1 to 127)
- when n = 0, and when [C], by the number stored in C, max. 127.

| Co  | ntrolle     | er instruc | tion                | R | G | Addr. |   |     |   |     | Flag |       |        | Example           |              |                     | Comment                           |
|-----|-------------|------------|---------------------|---|---|-------|---|-----|---|-----|------|-------|--------|-------------------|--------------|---------------------|-----------------------------------|
| OPP | OPA         | SRC        | Z-OPD               | А | Е | D     | R | [R] | v | CY  | 0    | Ν     | Z      |                   |              |                     |                                   |
| INC | B<br>W<br>D | R          | , n<br>, 0<br>, [C] |   |   | •     | • | •   |   | •   | •    | • •   | •      | INC<br>INC<br>INC | BY<br>W<br>W | A,5<br>A,0<br>B,[C] | Increment the contents of the SRC |
| DEC | B<br>W<br>D | R          | , n<br>, 0<br>, [C] |   |   | •     | • | •   |   | • • | •    | • • • | •<br>• | DEC<br>DEC<br>DEC | B<br>W<br>W  | A,5<br>A,0<br>B,[C] | Decrement the contents of the SRC |

# 7.14 Stack instructions

The available stack size comprises 256 double words. In the event of underflow, special marker S28.4 in the system area goes HIGH; overflow sets the S28.5 to HIGH. The I/O state deletes the entire application stack.

| Сог  | ntrolle | er instruc | tion  | R | G |   | Addr. |     |   |    | Flag | i. |   | Example  | Comment                                                                                      |
|------|---------|------------|-------|---|---|---|-------|-----|---|----|------|----|---|----------|----------------------------------------------------------------------------------------------|
| OPP  | OPA     | SRC        | Z-OPD | А | Е | D | R     | [R] | V | CY | 0    | Ν  | Z |          |                                                                                              |
| PUSH | D       | R          |       |   |   |   | •     |     |   |    |      |    |   | PUSH D O | Saves the register contents to application stack, and lowers the stack address.              |
| POP  | D       | R          |       |   |   |   | •     |     |   |    |      |    |   | POP D B  | Raises the application stack ad-<br>dress, and reads the saved con-<br>tents from the stack. |

## 7.15 No operation instructions & CARRY manipulations

| Со  | ntrolle | er instruc | tion  | R | G | Addr. type |   |     |   |    | Flag |   |   | Example | Comment                             |
|-----|---------|------------|-------|---|---|------------|---|-----|---|----|------|---|---|---------|-------------------------------------|
| OPP | OPA     | SRC        | Z-OPD | А | Е | D          | R | [R] | v | CY | 0    | Ν | Z |         |                                     |
| NOP |         |            |       |   |   |            |   |     |   |    |      |   |   | NOP     | No operation                        |
| SCY |         |            |       |   |   |            |   |     |   | •  |      |   |   | SCY     | Unconditionally set CARRY bit to 1. |
| RCY |         |            |       |   |   |            |   |     |   | •  |      |   |   | RCY     | Unconditionally set CARRY bit to 0. |

## 7.16 Shift instructions

Shift the contents of source operand SRC:

- by the number n
- when n = 0, and when [C], by the number stored in C.

| When OPA = D | then | n = 1 to 31 |
|--------------|------|-------------|
| When OPA = W | then | n = 1 to 15 |
| When OPA = B | then | n = 1 to 7  |

| Controller instruction |             |     | ction               | RG Addr. |   |   |   |     |   | Flag |   |   | Example | Comment                  |                             |
|------------------------|-------------|-----|---------------------|----------|---|---|---|-----|---|------|---|---|---------|--------------------------|-----------------------------|
| OPP                    | OPA         | SRC | Z-OPD               | А        | Е | D | R | [R] | V | CY   | 0 | Ν | Z       |                          |                             |
| SLR                    | B<br>W<br>D | R   | , n<br>, 0<br>, [C] |          |   | • | • | •   |   | •    | • | • | •<br>•  | SLR W A,7<br>SLR B B,[C] | SHIFT logical RIGHT         |
| SLL                    | B<br>W<br>D | R   | , n<br>, 0<br>, [C] |          |   | • | • | •   |   | •    | • | • | •       | SLL W A,7<br>SLL B B,[C] | SHIFT logical LEFT          |
| SAR                    | B<br>W<br>D | R   | , n<br>, 0<br>, [C] |          |   | • | • | •   |   | •    | • | • | •       | SAR W A,7<br>SAR B B,[C] | SHIFT arithmetical<br>RIGHT |

Logical SHIFT:



### Arithmetical SHIFT:

All bits being vacated are filled up with the contents of the MSB.



In the case of shift operations exceeding one space the overflow bit is set HIGH after a "1" was shifted through CY.

## 7.17 Rotate instructions

Shift the contents of source operand SRC:

- by the number n
- when n = 0, and when [C], by the number stored in C.

| When OPA = D | then | n = 1 to 31 |
|--------------|------|-------------|
| When OPA = W | then | n = 1 to 15 |
| When OPA = B | then | n = 1 to 7  |

| Со  | Controller instruction |     |                     | R | G | Addr. |   |     |   |    | Flag |   |   | Example                               | Comment                       |
|-----|------------------------|-----|---------------------|---|---|-------|---|-----|---|----|------|---|---|---------------------------------------|-------------------------------|
| OPP | OPA                    | SRC | Z-OPD               | А | Е | D     | R | [R] | V | CY | 0    | Ν | Z |                                       |                               |
| ROR | B<br>W<br>D            | R   | , n<br>, 0<br>, [C] |   |   | •     | • | •   |   | •  | •    | • | • | ROR B A,7<br>ROR W A,0<br>ROR W B,[C] | Rotate RIGHT                  |
| ROL | B<br>W<br>D            | R   | , n<br>, 0<br>, [C] |   |   | •     | • | •   |   | •  | •    | • | • | ROL B A,7<br>ROL W A,0<br>ROL W B,[C] | Rotate LEFT                   |
| RCR | B<br>W<br>D            | R   | , n<br>, 0<br>[C]   |   |   | •     | • | •   |   | •  | •    | • | • | RCR B A,7<br>RCR W A,0<br>RCR W B,[C] | Rotate RIGHT through<br>CARRY |
| RCL | B<br>W<br>D            | R   | , n<br>, 0<br>, [C] |   |   | •     | • | •   |   | •  | •    | • | • | RCL B A,7<br>RCL W A,0<br>RCL W B,[C] | Rotate LEFT through<br>CARRY  |

#### Rotate right:

ROR B, n



#### Rotate left

ROL B, N



Rotate right through CARRY

RCR B, n



Rotate left through CARRY

RCL B, n



In the case of a rotation by more than one space, the following applies:

- The overflow bit goes HIGH when a 1 has been rotated through CY.
- The negative bit goes HIGH when the MSB contains a 1.
  - MSB: Bit 7 when OPA = B

Bit 31 when OPA = D

# 7.18 Fixed point arithmetic

# 7.18.1 Add instructions

| Controller instruction |             | F                                                            | RG    | Addr. |   |         |   |     | Flag |                  |                  | Example          |                  | Comment                                              |                                                                     |                                                                                                 |
|------------------------|-------------|--------------------------------------------------------------|-------|-------|---|---------|---|-----|------|------------------|------------------|------------------|------------------|------------------------------------------------------|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|
| OPP                    | OPA         | SRC                                                          | Z-OPD | А     | Е | D       | R | [R] | V    | CY               | 0                | Ν                | Z                |                                                      |                                                                     |                                                                                                 |
| ADD                    | B<br>W<br>D | I/O/M/SM<br>T/C/K/SYM<br>S/DF/DP<br>D/DX<br>R<br>OPD[R]<br>P | , R   |       |   | • • • • | • | •   |      | •<br>•<br>•<br>• | •<br>•<br>•<br>• | •<br>•<br>•<br>• | •<br>•<br>•<br>• | ADD<br>ADD<br>ADD<br>ADD<br>ADD<br>ADD<br>ADD<br>ADD | W E0,A<br>B 0,B<br>W DP0,C<br>B D0,D<br>B B,C<br>W M[C],D<br>B P0,A | Fixed point addition of signed in-<br>tegers:<br>SRC + DEST = DEST                              |
| ADC                    | B<br>W<br>D | I/O/M/SM<br>T/C/K/SYM<br>S/DF/DP<br>D/DX<br>R<br>OPD[R]<br>P | , R   |       |   | • • • • | • | •   |      | •<br>•<br>•<br>• | •<br>•<br>•<br>• | •<br>•<br>•<br>• | •<br>•<br>•<br>• | ADC<br>ADC<br>ADC<br>ADC<br>ADC<br>ADC<br>ADC<br>ADC | W E0,A<br>B 0,B<br>W DP0,C<br>B D0,D<br>B B,C<br>W M[C],D<br>B P0,A | Fixed point addition of signed in-<br>tegers allowing for carry (CY):<br>SRC + DEST + CY = DEST |

#### Byte, word, and double-word addition

MSB:

- Bit 7 when OPA = B
- Bit 15 when OPA = W
- Bit 31 when OPA = D

ADD OPA B, O

| 7/15 |   | 0 |
|------|---|---|
| sg   | 0 |   |
|      | + |   |
| sg   | В |   |
|      | = |   |
| sg   | 0 |   |
|      |   |   |

0

+

С

=

0

+ CY

sg

sg

sg

ADC OPA C , O

#### Quad-word addition: Value 1 + value 2

Value 1: LOW DW in B, HIGH DW in A Value 2: LOW DW in D, HIGH DW in C

| Low-DW      |    |   |
|-------------|----|---|
|             | 31 | 0 |
| ADD D B , O | sg | А |
|             |    | + |
|             | sg | В |
|             |    | = |
|             | S  | 0 |
|             | g  |   |
|             |    |   |
|             |    |   |
| High-DW:    |    |   |
|             | 31 | 0 |
| ADD D B, O  | sg | А |
|             |    | + |

sg

sg

С

=

А

+ CY

## 7.18.2 Substract instructions

| C   | Controller instruction |                                                                 | ion   | RG Addr. |   |         |   |     |   | Flag             |                  |                  | Example          | Comment                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                               |
|-----|------------------------|-----------------------------------------------------------------|-------|----------|---|---------|---|-----|---|------------------|------------------|------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| OPP | ОРА                    | SRC                                                             | Z-OPD | А        | Е | D       | R | [R] | v | CY               | 0                | Ν                | Z                |                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                               |
| SUB | B<br>W<br>D            | I/O/M/SM<br>T/C/K/SYM<br>S/DP/DF/DP<br>D/DX<br>R<br>OPD[R]<br>P | , R   |          |   | • • • • | • | •   |   | •<br>•<br>•<br>• | •<br>•<br>•<br>• | •<br>•<br>•<br>• | •<br>•<br>•<br>• | SUB         W         E0,A           SUB         B         0,B           SUB         W         DP0,C           SUB         B         D0,D           SUB         B         B,C           SUB         W         M[C],D           SUB         B         P0,A                                                                                                                                                                                 | Fixed point subtraction of<br>signed integers<br>DEST - SRC = DEST.                                                           |
| SBB | B<br>W<br>D            | I/O/M/SM<br>T/C/K/SYM<br>S/DP/DF/DP<br>D/DX<br>R<br>OPD[R]<br>P | , R   |          |   | • • • • | • | •   |   | •                | • • • • • • •    | •<br>•<br>•<br>• | •<br>•<br>•<br>• | SBB         W         E0,A           SBB         B         0,B           SBB         W         DP0,C           SBB         B         D0,D           SBB         B         D,C           SBB         B         D,C | Fixed point subtraction of<br>signed integers allowing for<br>negative carry<br>(- Carry = Borrow)<br>DEST - SRC - CY = DEST. |

## Byte, word, double word subtraction:

MSB:

- Bit 7 when OPA = B
- Bit 15 when OPA = W
- Bit 31 when OPA = D

SUB OPA B , O

SBB OPA C , O

| 7/15 |   | 0  |
|------|---|----|
| sg   | 0 |    |
|      | - |    |
| sg   | В |    |
|      | = |    |
| sg   | 0 |    |
|      |   |    |
| sg   | 0 |    |
|      | - |    |
| sg   | С |    |
|      |   | -  |
|      |   | CY |
|      | = |    |
| sg   | 0 |    |

#### Quad-word subtraction: Value 1 – value 2

Value 1: LOW DW in B, HIGH DW in A Value 2: LOW DW in D, HIGH DW in C

#### Low-DW

|             | 31    | C | ) |
|-------------|-------|---|---|
| SUB D D , B | sg    | В |   |
|             |       | - |   |
|             | sg    | D |   |
|             |       | = |   |
|             | sg    | В |   |
|             | · · · |   | _ |
|             |       |   |   |
| High-DW:    |       |   |   |
|             | 31    | C | ) |
| SBB W C , O | sg    | 0 |   |
|             |       | _ |   |
|             | sg    | С |   |
|             |       | - | - |
|             |       | С | Y |
|             |       | = | _ |

sg

0

# 7.18.3 Multiply instructions

| Cor | Controller instruction RG |     |       |   |   | Addr | • |     |   | Flag |   |   | Example Commen |                        |                               |
|-----|---------------------------|-----|-------|---|---|------|---|-----|---|------|---|---|----------------|------------------------|-------------------------------|
| OPP | OPA                       | SRC | Z-OPD | А | Е | D    | R | [R] | v | CY   | 0 | Ν | Z              |                        |                               |
| MUL | В                         | K   | , R   |   |   | •    |   |     |   | 0    | 0 | • | •              | MUL B 100,A            | Fixed-point multiplication of |
|     | W<br>D                    | R   |       |   |   |      | • |     |   | 0    | 0 | • | •              | MUL W B,A<br>MUL D B,A | signed integers.              |

In multiplication, the product always occupies the double width of the output operands.

## Byte, word, multiplication



### Double word multiplication



## 7.18.4 Divide instructions

| Co  | Controller instruction RG |        |       |   |   | Addr |   | Flag Examp |   |        |   |   | Example | Comment                               |                                               |
|-----|---------------------------|--------|-------|---|---|------|---|------------|---|--------|---|---|---------|---------------------------------------|-----------------------------------------------|
| OPP | OPA                       | SRC    | Z-OPD | А | Е | D    | R | [R]        | v | CY     | 0 | Ν | Z       |                                       |                                               |
| DIV | B<br>W<br>D               | K<br>R | , R   |   |   | •    | • |            |   | 0<br>0 | • | • | •       | DIV B 100,A<br>DIV W B,A<br>DIV D B,A | Fixed-point division of signed in-<br>tegers. |

In division, the dividend always occupies the double width of the divisor.

#### Byte, word division



#### **Double-word division**

|                               | 32          |
|-------------------------------|-------------|
| DIV D C , O ; DEST-D sg<br>+1 | В           |
| 31                            |             |
| ; DEST-D                      | 0           |
| 31                            | :           |
| ; SRC-D sg                    | C           |
|                               | =           |
| ; DEST-D sg                   | A: Quotient |
|                               | and         |
| ; DEST-D<br>+1                | B: Rest     |

In the case of a division by 0, the division instruction is not carried out, and the overflow bit is set HIGH. The overflow bit is also set HIGH in the case of division overflow.

## 7.19 Floating point arithmetic

#### Data formats, accuracy

Floating point arithmetic supports the data formats specified in the IEEE 754 and IEE 854 standards.

Two data formats, **REAL** and **LREAL**, are defined in accordance with IEC1131.

| Data format                                                       | Data width | Mantissa | Exponent | Range              |
|-------------------------------------------------------------------|------------|----------|----------|--------------------|
| REAL:<br>Short real floating point<br>number,<br>single precision | 32 bits    | 24 bits  | 8 bits   | 10 <sup>±38</sup>  |
| LREAL:<br>Long real floating point<br>number,<br>double precision | 64 bits    | 53 bits  | 11 bits  | 10 <sup>±308</sup> |

Data format L always uses the register pairs AB and CD.

When calculating with the REAL data format, inaccuracies in the decimal range will occur sooner than with the LREAL format. If a high degree of accuracy is required, the LREAL format should be used.

#### Appropriate conversion routines are available in WinSPS from version 2.4 onwards.

#### Value range and resolution

The floating point formats do not permit the representation of all numbers in any desired resolution. For example, if one wants to work with a unit of measure such as 2m, which is quite common in mechanical engineering, the REAL data format permits, for each individual  $\mu$ m, a representation with a limit value of 16.0 metres. If the LREAL format is chosen instead, the representation of numbers up to 17,179,869,184.0 m becomes possible.

| Reso                                    | olution                    | Value        | limit                    |
|-----------------------------------------|----------------------------|--------------|--------------------------|
| Floating point notation                 | Exponential notation       | REAL         | LREAL                    |
| 1,0                                     | E <sup>0</sup>             | 16.777.228,0 | 18.014.398.509.481.984,0 |
| 0,1                                     | E <sup>-1</sup>            | 1.048.576,0  | 1.125.899.906.842.624,0  |
| 0,01                                    | E <sup>-2</sup>            | 131.072,0    | 140.737.488.355.328,0    |
| 0,001                                   | E <sup>-3</sup> milli (m)  | 16.384,0     | 17.592.186.044.416,0     |
| 0,0001                                  | E <sup>-4</sup>            | 1.024,0      | 1.099.511.627.776,0      |
| 0,00001                                 | E <sup>-5</sup>            | 128,0        | 137.438.953.472,0        |
| 0,000001                                | E <sup>-6</sup> micro (μ)  | 16,0         | 17.179.869.184,0         |
| 0,0000001                               | E <sup>-7</sup>            | 1,0          | 1.073.741.824,0          |
| 0,0000001                               | E <sup>-8</sup>            | 0,125        | 134.217.728,0            |
| 0,00000001                              | E <sup>-9</sup> nano (n)   | 0,015625     | 16.777.216,0             |
| 0,000000001                             | E <sup>-10</sup>           | 0,000976563  | 1.048.576,0              |
| 0,0000000001                            | E <sup>-11</sup>           |              | 131.072,0                |
| 0,00000000001                           | E <sup>-12</sup> pico (p)  |              | 16.384,0                 |
| 0,000000000001                          | E <sup>-13</sup>           |              | 1.024,0                  |
| 0,0000000000001                         | E <sup>-14</sup>           |              | 128,0                    |
| 0,000000000000000                       | E <sup>-15</sup> femto (f) |              | 16,0                     |
| 0,0000000000000000000000000000000000000 | E <sup>-16</sup>           |              | 1,0                      |
| 0,0000000000000000000000000000000000000 | E <sup>-17</sup>           |              | 0,125                    |
| 0,0000000000000000000000000000000000000 | E <sup>-18</sup> atto (a)  |              | 0,015625                 |

| Operands     | <ul> <li>Depending on the instruction, the following may be used as floating point operands:</li> <li>M, S, DM, DF, D, DXwith both direct and indirect addressing.</li> </ul>                                                                                                                                                                                                                                          |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | <ul> <li>The specified operand address must</li> <li>be divisible as follows: by 4 for REAL data format and</li> <li>by 8 for LREAL data format.</li> <li>K, register</li> </ul>                                                                                                                                                                                                                                       |
| E]           | P: A PM parameter may not be used as a floating-point constant. In the event that this is required, the constant may first be loaded into a marker word, for example.                                                                                                                                                                                                                                                  |
| Instructions | <ul> <li>The floating-point data formats and operands may be used in the following instruction types:</li> <li>LOAD floating point value</li> <li>TRANSFER floating point value</li> <li>CONVERT</li> <li>COMPARE floating point values</li> <li>Basic arithmetic functions</li> <li>Forming absolute value</li> <li>Extracting square root</li> <li>Logarithmic functions</li> <li>Trigonometric functions</li> </ul> |

# Error displays, range overlaps

FPU errors (division by 0, ...) cause an "Error stop" in the iPCL führen in der iPCL, range overlaps cause a "Stop".

# 7.19.1 Loadfloating point values

| С   | ontro  | ller instruct                                   | ion   | R | G |   | Addr | •   |   |    | Flag |   |   | Example                                                                     | Comment                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|--------|-------------------------------------------------|-------|---|---|---|------|-----|---|----|------|---|---|-----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OPP | OPA    | SRC                                             | Z-OPD | А | Е | D | R    | [R] | V | CY | 0    | Ν | Z |                                                                             |                                                                                                                                                                                                                                                                                                                                                                                           |
| L   | R<br>L | K<br>R<br>M, S,<br>DP, DF, D, DX<br>P<br>OPD[R] | , R   |   |   | • | •    | •   |   |    |      |   |   | L R 12,321,A<br>L L A,C<br>L L M8,C<br>L R DF16,B<br>L R P0,D<br>L L D[A],C | $\label{eq:result} \begin{array}{l} \text{REAL constant} \rightarrow \text{Reg. A} \\ \text{LREAL reg. pair AB} \rightarrow \text{CD} \\ \text{LEAL M8-M15} \rightarrow \text{Reg. pair CD} \\ \text{REAL DF16-DF23} \rightarrow \text{Reg. B} \\ \text{REAL P0} \rightarrow \text{Reg. D} \\ \text{LREAL contents of operand addressed by reg. A} \rightarrow \text{reg. C} \end{array}$ |

# 7.19.2 TRANSFERfloating point values

|     | Contr  | oller in | struction                                     | R | G |   | Addı | r.  |   |    | Flag |   |   | Example                                        | Comment                                                                                                                                                                    |
|-----|--------|----------|-----------------------------------------------|---|---|---|------|-----|---|----|------|---|---|------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OPP | OPA    | SRC      | Z-OPD                                         | А | Е | D | R    | [R] | V | CY | 0    | Ν | z |                                                |                                                                                                                                                                            |
| Т   | R<br>L | R        | , M, S,<br>, DP, DF, D, DX<br>, P<br>, OPD[R] |   |   | • |      | •   |   |    |      |   |   | T R A,M0<br>T L A,DF0<br>T R D,P0<br>T L D,[A] | REAL reg. A $\rightarrow$ M0-M3<br>LREAL reg. pair AB $\rightarrow$ DF0-DF7<br>REAL reg. D $\rightarrow$ P0<br>LREAL contents of reg. D to<br>operand addressed by reg. A. |

# 7.19.3 CONVERT number formats (floating point <-> integer)

- 32Converting 32-bit integer values to floating-point REAL / LREAL.
- Converting floating-point REAL / LREAL to 32-bit integer values.

| Со  | ntrolle | er instruc | tion  | R | G |   | Addr |     |   |    | Flag |   |   | E>         | kan    | nple   | Comment                                                                                                                                                                                                    |
|-----|---------|------------|-------|---|---|---|------|-----|---|----|------|---|---|------------|--------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OPP | OPA     | SRC        | Z-OPD | А | Е | D | R    | [R] | V | CY | 0    | Ν | z |            |        |        |                                                                                                                                                                                                            |
| ITF | R<br>L  | R          |       |   |   |   | •    |     |   |    |      |   |   | ITF        | R      | -      | Converts 32-bit integer value from<br>reg. A to REAL floating point format.<br>Converts 32-bit integer value from<br>reg. C to LREAL floating point for-<br>mat.<br>The result is written to reg. pair CD. |
| FTI | R<br>L  | R          |       |   |   |   | •    |     |   |    |      |   |   | FTI<br>FTI | R<br>L | 0<br>C | Converts REAL floating point from<br>reg. A to 32-bit integer value.<br>Converts LREAL floating point from<br>reg. pair CD to 32-bit integer value.<br>The result is written to reg. C.                    |

# 7.19.4 Convert data formats (REAL <--> LREAL)

In the REAL data format, inaccuracies may occur in the positions after the decimal point. If better accuracy is required, the LREAL data format must be used. To handle the required data format conversion, specific conversion instructions are provided.

| Со  | ntrolle | er instruc | tion  | R | G |   | Addr | •   |   |    | Flag |   |   | Ex         | am | ple    | Comment                                                                                                                                                                                          |
|-----|---------|------------|-------|---|---|---|------|-----|---|----|------|---|---|------------|----|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OPP | OPA     | SRC        | Z-OPD | А | Е | D | R    | [R] | V | CY | 0    | Ν | Z |            |    |        |                                                                                                                                                                                                  |
| RTL |         | R          |       |   |   |   | •    |     |   |    |      |   |   | RTL<br>RTL |    | O<br>C | Converts the REAL value of register<br>A to an LREAL value. Destination<br>register pair = AB.<br>Converts the REAL value of register<br>C to an LREAL value. Destination<br>register pair = CD. |
| LTR | R       | R          |       |   |   |   | •    |     |   |    |      |   |   | LTR<br>LTR | L  | -      | Converts the LREAL value of register<br>pair AB to a REAL value.Destination<br>register = A.<br>Converts LREAL value in register<br>pair CD to a REAL value.Destination<br>register = C.         |

# 7.19.5 Removing decimal positions

| Со  | ntrolle | er instruc | tion  | R | G |   | Addr |     |   |    | Flag |   | i. | Example | Comment                                                                            |
|-----|---------|------------|-------|---|---|---|------|-----|---|----|------|---|----|---------|------------------------------------------------------------------------------------|
| OPP | OPA     | SRC        | Z-OPD | А | Е | D | R    | [R] | V | CY | 0    | Ν | Z  |         |                                                                                    |
| TRC | R<br>L  | R          |       |   |   |   | •    |     |   |    |      |   |    | TRC R O | Writes the value in register A back to register A but without decimal positions.   |
|     |         |            |       |   |   |   |      |     |   |    |      |   |    | TRC L C | Writes the value in register pair CD back to CD but without the decimal positions. |

## 7.19.6 Comparefloating point values

| Со   | ntrolle | er instruc       | ction | R | G |   | Ad | dr. |   |    |   | Fla | ag |    |    | Example       | Comment                                                                                |
|------|---------|------------------|-------|---|---|---|----|-----|---|----|---|-----|----|----|----|---------------|----------------------------------------------------------------------------------------|
| OPP  | OPA     | SRC              | Z-OPD | А | Е | D | R  | [R] | V | CY | 0 | Ν   | Ζ  | AG | LG |               |                                                                                        |
| CPLA | R       | M/K              | , R   |   |   | • |    |     |   | •  |   | •   | •  | •  | •  | CPLA R M4,A   | Compare REAL M4 to M7<br>with register A.                                              |
|      | L       | S/DF/<br>D/DX/DP |       |   |   | • |    |     |   | •  |   | •   | •  | •  | •  | CPLA L D200,C | Compare LREAL D200 to D208 with register CD.                                           |
|      |         | R                |       |   |   |   | •  |     |   | •  |   | •   | •  | •  | •  | CPLA L A,C    | Compare LREAL register pair AB with CD.                                                |
|      |         | Р                |       |   |   | • |    | •   |   | •  |   | •   | •  | •  | •  | CPLA R P62,A  | Compare REAL P62 with register A.                                                      |
|      |         | OPD[R]           |       |   |   |   |    |     |   | •  |   | •   | •  | •  | •  | CPLA L M[C],A | Compare LREAL contents of<br>operand addressed by register C<br>with register pair AB. |

When comparing the REAL and LREAL data formats, the flags require arithmetical interpretation.

Examples:

| Compare<br>DEST (A) with SRC (B) |                               | CPLA B,A<br>Jump instruction |
|----------------------------------|-------------------------------|------------------------------|
| Equal                            | A=B                           | JPZ                          |
| Unequal                          | A≠B                           | JPN                          |
| Less than                        | A <b< td=""><td>JPM</td></b<> | JPM                          |
| Less than / equal                | A≤B                           | JPMZ                         |
| Greater than                     | A>B                           | JPAG                         |
| Greater than / equal             | A≥B                           | SPP                          |

- When using the CPLA instruction, the evaluation of the compare results must always be programmed immediately following the compare instruction itself. The user is advised to bear in mind that binary operations will cause a modification of the state bits. Therefore, a compare result can be used only in a link. Following this, another CPLA instruction must again be programmed.
- IF With various resolutions (decimal positions) the compare operation in the REAL data format returns correct results only up to specific limit values.

#### **Resolution / Value limit**

| Resolution  | Value limit |
|-------------|-------------|
| 0,001953125 | 256,0000    |
| 0,03125000  | 2048,000    |
| 0,2500000   | 32768,00    |
| 2,000000    | 262144,0    |
| 32,00000    | 2097152     |

#### Example:

L R 2048.00000,A CPLA R 2048.00009,A

The difference is not found, and the numbers are recognized as being equal, Z = 1.

For large numbers at high resolution the LREAL data format must be used.

## 7.19.7 Calculating with floating point values

For working with floating-point values, the following basic arithmetic functions are available:

- Addition
- Subtraction
- Multiplication
- Division

The instructions handling the four basic arithmetic functions calculate the contents of the destination register or register pair with the contents of the source operand. The results are always written to the destination register or register pair.

| C          | ontro | oller instructi                         | on    | R | G |   | Add | r.  |   | F  | Flag |   |   | E                               | xample                                             | Comment                                                                                                                                                                                                        |
|------------|-------|-----------------------------------------|-------|---|---|---|-----|-----|---|----|------|---|---|---------------------------------|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OPP        | OPA   | SRC                                     | Z-OPD | А | Е | D | R   | [R] | V | CY | 0    | Ν | Z |                                 |                                                    |                                                                                                                                                                                                                |
| ADD<br>SUB | RL    | M/K<br>S/DF/D/DX/DP<br>R<br>P<br>OPD[R] | , R   |   |   | • | •   | •   | • |    | •    | • | • | ADD<br>SUB<br>ADD<br>SUB<br>SUB | R M2,A<br>L D200,C<br>L A,C<br>R P62,A<br>L M[C],A | REAL M2 to M5 plus reg. A con-<br>tents.<br>LREAL reg. CD minus D200 to<br>D208<br>LREAL reg. pair AB + CD<br>REAL reg. A minus P62<br>LREAL contents of reg. pair AB<br>minus operand addressed by<br>reg. C. |
| MUL        | R     | К                                       | , R   |   |   | • |     |     | • |    | •    | • | • | MUL                             | R 123.45,A                                         | REAL 123.45 multiplied by con-<br>tents of reg. A                                                                                                                                                              |
| DIV        | L     | R                                       |       |   |   |   | •   |     | • |    | •    | • | • | DIV                             | L A,C                                              | LREAL reg. pair AB divided by reg. pair CD                                                                                                                                                                     |

# 7.19.8 Forming absolute value

Absolute values are always formed using a register or register pair. The result is then placed in the same register or register pair as a signed integer.

| Controller instruction |        |     | R     | G | Addr. |   |   |     |   |    |   | Example |   |            | Comment |        |                                                                                                                       |
|------------------------|--------|-----|-------|---|-------|---|---|-----|---|----|---|---------|---|------------|---------|--------|-----------------------------------------------------------------------------------------------------------------------|
| OPP                    | OPA    | SRC | Z-OPD | А | Е     | D | R | [R] | V | CY | 0 | Ν       | Z |            |         |        |                                                                                                                       |
| ABS                    | R<br>L | R   |       |   |       |   | • |     | • |    | • | •       | • | ABS<br>ABS | R<br>L  | 0<br>C | Return absolute value of REAL con-<br>tents of reg A.<br>Return absolute value of LRLEAL<br>contents of reg. pair CD. |

## 7.19.9 Extracting square root

Square root extraction always uses a register or register pair. The result is then written to the same register or register pair.

| Controller instruction |        |     | R     | G | Addr. |   |   |     |   | Flag |   |   | Example | Comment              |                                                                                                                              |
|------------------------|--------|-----|-------|---|-------|---|---|-----|---|------|---|---|---------|----------------------|------------------------------------------------------------------------------------------------------------------------------|
| OPP                    | OPA    | SRC | Z-OPD | А | Е     | D | R | [R] | V | CY   | 0 | Ν | Z       |                      |                                                                                                                              |
| SQRT                   | R<br>L | R   |       |   |       |   | • |     | • |      | • | • | •       | SQRT R O<br>SQRT L C | Extract square root of REAL con-<br>tents of register A.<br>Extract square root of LRLEAL con-<br>tents of register pair CD. |

## 7.19.10 Exponentiation

For exponentiation XY, the following procedure is used:

- In REAL format, registers A and C are used, with register A holding the base, and C the exponent. The result is written to register A.
- In LREAL format, register pairs AB and CD are used, with AB holding the base, and CD the exponent. The result is written to register pair AB.

| Controller instruction |        |     | R     | G | Addr. |   |   |     | i. | Flag | 1 |   | Example | Comment   |                                                                                                                                  |
|------------------------|--------|-----|-------|---|-------|---|---|-----|----|------|---|---|---------|-----------|----------------------------------------------------------------------------------------------------------------------------------|
| OPP                    | ОРА    | SRC | Z-OPD | А | Е     | D | R | [R] | V  | CY   | 0 | Ν | z       |           |                                                                                                                                  |
| POW                    | R<br>L | R   | R     |   |       |   | • |     | •  |      | • | • | •       | POW R A,C | Exponentiate the REAL contents of<br>register A with the REAL contents of<br>register C. The result is written to<br>register A. |
|                        |        |     |       |   |       |   |   |     |    |      |   |   |         | POW L A,C | Exponentiate the LREAL contents of register pair AB with the LREAL contents of CD. The result is written to register pair AB.    |

## 7.19.11 Logarithmic functions

The instructions for logarithmic functions calculate the contents of a register or register pair. The results are always written to the destination register or register pair.

Implemented are:

- Natural logarithms
- Base-10 logarithms
- Forming exponential functions from base-10 (common) logarithms

| Controller instruction |        |     | R     | G | Addr. type |   |   |     |   | Flag |   | i. | Example | Comment                   |                                                                                                                                                                                                                          |
|------------------------|--------|-----|-------|---|------------|---|---|-----|---|------|---|----|---------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OPP                    | OPA    | SRC | Z-OPD | А | Е          | D | R | [R] | V | CY   | 0 | Ν  | Z       |                           |                                                                                                                                                                                                                          |
| LN<br>LOG<br>EXP       | R<br>L | R   |       |   |            |   | • |     | • |      | • | •  | •       | LN RO<br>LOG LC<br>EXP RC | Form natural logarithm from REAL<br>contents of register A.<br>Form common logarithm from<br>LREAL contents of register pair CD.<br>Form exponential value from com-<br>mon logarithm of REAL contents of<br>register C. |

## 7.19.12 Trigonometric functions floating point

The instructions for trigonometric functions calculate the contents of a register or register pair. The results are always written to the destination register or register pair.

Implemented are:

- Sine, with entry in radian measure
- Cosine, with entry in radian measure
- Tangent, with entry in radian measure
- Arc sine, main value
- Arc cosine, main value
- Arc tangent, main value

| Controller instruction |        |     | R     | G | Addr. type |   |   |     | i. |    |   | Example |   |      | Comment |   |                                                               |
|------------------------|--------|-----|-------|---|------------|---|---|-----|----|----|---|---------|---|------|---------|---|---------------------------------------------------------------|
| OPP                    | OPA    | SRC | Z-OPD | А | Е          | D | R | [R] | V  | CY | 0 | Ν       | Z |      |         |   |                                                               |
| SIN<br>COS             | R<br>L | R   |       |   |            |   | • |     | •  |    | • | •       | • | SIN  | R       | 0 | Form sine from REAL contents<br>of register A.                |
| TAN<br>ASIN            |        |     |       |   |            |   |   |     |    |    |   |         |   | COS  | L       | С | Form cosine from LREAL contents<br>of register pair CD.       |
| ACOS<br>ATAN           |        |     |       |   |            |   |   |     |    |    |   |         |   | TAN  | R       | С | Form tangent from REAL contents of register C.                |
|                        |        |     |       |   |            |   |   |     |    |    |   |         |   | ASIN | R       | 0 | Form arc sine from REAL contents of register A.               |
|                        |        |     |       |   |            |   |   |     |    |    |   |         |   | ACOS | L       | С | Form arc cosine from LREAL con-<br>tents of register pair CD. |
|                        |        |     |       |   |            |   |   |     |    |    |   |         |   | ATAN | R       | С | Form arc tangent from REAL con-<br>tents of register C.       |

### 7.20 Parameter assignments

| С   | ontro       | ller instructi                                 | on    | R | G | Addr. |   |     |   |    | Flag |   |   | Example                                                                                                      | Comment                                              |
|-----|-------------|------------------------------------------------|-------|---|---|-------|---|-----|---|----|------|---|---|--------------------------------------------------------------------------------------------------------------|------------------------------------------------------|
| OPP | OPA         | SRC                                            | Z-OPD | А | Е | D     | R | [R] | V | CY | 0    | Ν | Z |                                                                                                              |                                                      |
| Pn  | B<br>W<br>D | I/O/M/T/C/K<br>S/SM/SYM<br>D/DX/DF/DP<br>FC/DM |       |   |   | •     |   |     |   |    |      |   |   | P0         W         I0.0           P1         W         S0           P2         D0           P3         PM0 | Parameter definition for parameterized module calls. |

# 7.21 Local symbol names & auxiliary markers for program tracking

| C   | ontro | ller instruc                                   | tion  | R | G | Addr. type |   |     |   | .  | Flag |   |   | Example                          | Comment                                                                                                                                                                                                                                    |
|-----|-------|------------------------------------------------|-------|---|---|------------|---|-----|---|----|------|---|---|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OPP | OPA   | SRC                                            | Z-OPD | А | Е | D          | R | [R] | v | CY | 0    | Ν | z |                                  |                                                                                                                                                                                                                                            |
| DEF |       | I/O/M/T/C/K<br>S/SM/SYM<br>D/DX/DF/DP<br>FC/DM | , SYM |   |   |            |   |     |   |    |      |   |   | DEF I0.0,-Symbol<br>DEF I0,-Name | Definition of symbolic names that<br>are locally valid only within the<br>module in which they have been<br>entered. Essential for the creation<br>of library modules.                                                                     |
| *   |       | n<br>n = 0-63                                  |       |   |   |            |   |     |   |    |      |   |   | *1 1                             | Definition of auxiliary markers for<br>program tracking.<br>Processing of these auxiliary<br>markers is written only to the<br>marker buffer, and can be inter-<br>preted only in case of an error. *N<br>has no influence on the program. |

### 7.22 System variable

| Cont | roller | instruc | ction | R | G |   | Add | r.  |   | ļ  | Flag |   |   | Example       | Comment                                            |
|------|--------|---------|-------|---|---|---|-----|-----|---|----|------|---|---|---------------|----------------------------------------------------|
| OPP  | OPA    | SRC     | Z-OPD | А | Е | D | R   | [R] | v | CY | 0    | Ν | Z |               |                                                    |
| DEFW | W      | К       |       |   |   |   |     |     |   |    |      |   |   | DEFW W K0000H | Definition of function for system variable in OM2. |

### 7.23 Jump instructions

Jump instructions may be executed unconditionally, and also in dependence on a binary link and/or a mathematical operation (see also Section 7.2 Flags). With one exception (JP [R]), jump instructions are programmed symbolically, but the entry point may not be located within a program branch because this would also cause the RES at the jump origin point to be linked.

| Cor  | ntrolle | r instru      | ction | R | G |   | Add | dr. |   |   |   | Fla | ıg |    |    | Ex       | ample          | Comment                                                                                              |
|------|---------|---------------|-------|---|---|---|-----|-----|---|---|---|-----|----|----|----|----------|----------------|------------------------------------------------------------------------------------------------------|
| OPP  | OPA     | SRC           | Z-OPD | А | Е | D | R   | [R] | v | С | 0 | Ν   | Z  | AG | LG |          |                |                                                                                                      |
| JP   |         | SYM<br>[R],n* |       |   |   | • |     | •   |   |   |   |     |    |    |    | JP<br>JP | -LABEL1<br>[A] | Unconditional to -LABEL des-<br>tination.<br>Unconditional by jump distance<br>(byte) in register A. |
| JPB  |         | SYM           |       |   | • | • |     |     | 1 |   |   |     |    |    |    | JPB      | -LABEL2        | Conditional, see flags.                                                                              |
| JPCI |         | SYM           |       |   | • | • |     |     | 0 |   |   |     |    |    |    | JPCI     | -LABEL3        | Conditional, see flags.                                                                              |
| JPCY |         | SYM           |       |   |   | • |     |     |   | 1 |   |     |    |    |    | JPCY     | -LABEL4        | Conditional, see flags.                                                                              |
| JPCN |         | SYM           |       |   |   | • |     |     |   | 0 |   |     |    |    |    | JPCN     | -LABEL5        | Conditional, see flags.                                                                              |
| JP0  |         | SYM           |       |   |   | • |     |     |   | Ì | 1 |     |    |    | 1  | JPO      | -LABEL6        | Conditional, see flags.                                                                              |
| JPON |         | SYM           |       |   |   | • |     |     |   |   | 0 |     |    |    |    | JPON     | -LABEL7        | Conditional, see flags.                                                                              |
| JPM  |         | SYM           |       |   |   | • |     |     |   |   |   | 1   |    |    |    | JPM      | -LABEL8        | Conditional, see flags.                                                                              |
| SPP  |         | SYM           |       |   |   | • |     |     |   |   |   | 0   |    |    |    | SPP      | -LABEL9        | Conditional, see flags.                                                                              |
| JPZ  |         | SYM           |       |   |   | • |     |     |   | Ì |   |     | 1  |    | 1  | JPZ      | -LABEL10       | Conditional, see flags.                                                                              |
| JPN  |         | SYM           |       |   |   | • |     |     |   |   |   |     | 0  |    |    | JPN      | -LABEL11       | Conditional, see flags.                                                                              |
| JPAG |         | SYM           |       |   |   | • |     |     |   |   |   |     |    | 1  |    | JPAG     | -LABEL12       | Conditional, see flags.                                                                              |
| JPMZ |         | SYM           | Ì     |   | İ | • | İ   |     |   |   |   | İ   |    | 0  |    | JPMZ     | -LABEL13       | Conditional, see flags.                                                                              |
| JPLG |         | SYM           |       |   |   | • |     |     |   |   |   |     |    |    | 1  | JPLG     | -LABEL14       | Conditional, see flags.                                                                              |
| JPCZ |         | SYM           |       |   |   | • |     |     |   |   |   |     |    |    | 0  | JPCZ     | -LABEL15       | Conditional, see flags.                                                                              |

The JP [R] instruction causes an unconditional jump whose jump destination must always be a jump instruction. This instruction variant was created specifically for the simple implementation of jump distributors. The controller monitors the instruction mnemonics of the entry point, and enters STOP mode if this fails to correspond to a jump instruction. In such cases, the error status of the Programming Unit (PG) provides information about the cause of the error.

The parameter n can be specified for the purpose of jump sequence monitoring, i.e. n can be less than or equal to the jump count.

The following example demonstrates the application of this jump instruction.

### Example:

### PLC-program interlude

| Fixed p | orogram sequen | ce                                                                                                                            |
|---------|----------------|-------------------------------------------------------------------------------------------------------------------------------|
| only ha |                | ion in register A for the following jump sequence A may<br>ed values (1, 3, 5,). The parameter n must not be less<br>o count. |
| JP      | [A],n          | ; 1 word instruction                                                                                                          |
| JP      | Dest1          | ; 2 word instruction                                                                                                          |
| JP      | Dest2          | ; 2 word instruction                                                                                                          |
| :       |                |                                                                                                                               |
| :       |                |                                                                                                                               |
| JP      | Destn          | ; 2 word instruction                                                                                                          |

| Dest1:   |      | ; | Program | part | 1 |
|----------|------|---|---------|------|---|
| PLC prog | gram |   |         |      |   |
| JP       | End  |   |         |      |   |

| Dest2:      | ; Program part 2 |
|-------------|------------------|
| PLC program |                  |
| JP End      |                  |
|             |                  |

| Destn:  |      | ; Program part n |
|---------|------|------------------|
| PLC pro | gram |                  |
| JP      | End  |                  |

| :   |           |         |
|-----|-----------|---------|
| :   |           |         |
| End |           |         |
| PLC | successor | program |
| :   |           |         |

### 7.24 Module calls

Module call instructions may be executed unconditionally, and also in dependence on a binary link and/or a mathematical operation (see also Section 7.2 Flags).

The iPCL supports a module nesting depth of 63 program modules.

Two data modules may be kept enabled at the same time. For this purpose the following module calls are available:

CM, BAB, BAI DMn: enables DMn as 1st DM BX, BXB, BAI DMy: enables DMy as 2nd DM

| Cor         | ntrolle | r instru                          | ction      | R | G | Ac      | ddr. t | уре |   |    | Flag |   |   | Example                                                                                                                                               | Comment                                                                                                                                       |
|-------------|---------|-----------------------------------|------------|---|---|---------|--------|-----|---|----|------|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| OPP         | OPA     | SRC                               | Z-OPD      | А | Е | D       | R      | [R] | v | CY | 0    | Ν | z |                                                                                                                                                       |                                                                                                                                               |
| CM<br>BX    |         | DM<br>PM<br>P<br>P<br>P<br>PM[R]  | , n<br>, n |   |   | •       |        | •   |   |    |      |   |   | CM         DM0           CM         PM0           CM         PM1,2           CM         P0           CM         P0,2           CM         PM[A]       | Unconditional, direct.<br>Parameterized, list to follow.<br>As parameter.<br>As parameter; para., list to fol-<br>low.<br>Indirect            |
| CMC<br>BXB  |         | DM<br>PM<br>PM<br>P<br>P<br>PM[R] | , n<br>, n |   | • | •       |        | •   | 1 |    |      |   |   | CMC DM0<br>CMC PM0<br>CMC PM1,2<br>CMC P0<br>CMC P0,2<br>CMC P0,2<br>CMC PM[A]                                                                        | Conditional, see flags.<br>Direct<br>Parameterized, list to follow.<br>As parameter.<br>As parameter; para., list to fol-<br>low.<br>Indirect |
| CMCI<br>BXI |         | DM<br>PM<br>P<br>P<br>PM[R]       | , n<br>, n |   | • | • • • • |        | •   | 0 |    |      |   |   | CMCI DM0<br>CMCI PM0<br>CMCI PM1,2<br>CMCI P0<br>CMCI P0,2<br>CMCI PM[A]                                                                              | Conditional, see flags.<br>Direct<br>Parameterized, list to follow.<br>As parameter.<br>As parameter; para., list to fol-<br>low.<br>Indirect |
| CMCY        |         | DM<br>PM<br>P<br>P<br>PM[R]       | , n<br>, n |   |   | •       |        | •   |   | 1  |      |   |   | CMCY DM0<br>CMCY PM0<br>CMCY PM1,2<br>CMCY P0<br>CMCY P0,2<br>CMCY PM[A]                                                                              | Conditional, see flags.<br>Direct<br>Parameterized, list to follow.<br>As parameter.<br>As parameter; para., list to fol-<br>low.<br>Indirect |
| CMCN        |         | DM<br>PM<br>P<br>P<br>PM[R]       | , n<br>, n |   |   | • • • • |        | •   |   | 0  |      |   |   | CMCNDM0CMCNPM0CMCNPM1,2CMCNP0CMCNP0,2CMCNPM[A]                                                                                                        | Conditional, see flags.<br>Direct<br>Parameterized, list to follow.<br>As parameter.<br>As parameter; para., list to fol-<br>low.<br>Indirect |
| СМО         |         | DM<br>PM<br>P<br>P<br>PM[R]       | , n<br>, n |   |   | • • • • |        | •   |   |    | 1    |   |   | CMO         DM0           CMO         PM0           CMO         PM1,2           CMO         P0           CMO         P0,2           CMO         PM[A] | Conditional, see flags.<br>Direct<br>Parameterized, list to follow.<br>As parameter.<br>As parameter; para., list to fol-<br>low.<br>Indirect |
| CMON        |         | DM<br>PM<br>P<br>P<br>PM[R]       | , n<br>, n |   |   | • • • • |        | •   |   |    | 0    |   |   | CMONDM0CMONPM0CMONPM1,2BAPNP0CMONP0,2CMONPM[A]                                                                                                        | Conditional, see flags.<br>Direct<br>Parameterized, list to follow.<br>As parameter.<br>As parameter; para., list to fol-<br>low.<br>Indirect |

### Module calls continued

| Con  | trolle | r instru                          | ction      | R | G |             | Add | lr. |   |    |   | Fla | ag |    |    | Exa                                           | mple                                       | Comment                                                                                                                          |
|------|--------|-----------------------------------|------------|---|---|-------------|-----|-----|---|----|---|-----|----|----|----|-----------------------------------------------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| OPP  | OPA    | SRC                               | Z-OPD      | Α | Е | D           | R   | [R] | v | CY | 0 | Ν   | z  | AG | LG |                                               |                                            |                                                                                                                                  |
| СММ  |        | DM<br>PM<br>P<br>P<br>P<br>[R]    | , n<br>, n |   |   | •<br>•<br>• |     | •   |   |    |   |     |    |    |    | CMM<br>CMM<br>CMM<br>CMM<br>CMM<br>CMM        | DM0<br>PM0<br>PM1,2<br>P0<br>P0,2<br>PM[A] | Conditional, see flags.<br>Direct<br>Parameterized, list to follow.<br>As parameter.<br>As parameter, parameterized.<br>Indirect |
| CMP  |        | DM<br>PM<br>PM<br>P<br>[R]        | , n<br>, n |   |   | •<br>•<br>• |     | •   | 1 |    |   |     |    |    |    | CMP<br>CMP<br>CMP<br>CMP<br>CMP<br>CMP<br>CMP | DM0<br>PM0<br>PM1,2<br>P0<br>P0,2<br>PM[A] | Conditional, see flags.<br>Direct<br>Parameterized, list to follow.<br>As parameter.<br>As parameter, parameterized.<br>Indirect |
| CMZ  |        | DM<br>PM<br>PM<br>P<br>P<br>PM[R] | , n<br>, n |   |   | •<br>•<br>• |     | •   | 0 |    |   |     |    |    |    | CMZ<br>CMZ<br>CMZ<br>CMZ<br>CMZ<br>CMZ        | DM0<br>PM0<br>PM1,2<br>P0<br>P0,2<br>PM[A] | Conditional, see flags.<br>Direct<br>Parameterized, list to follow.<br>As parameter.<br>As parameter, parameterized.<br>Indirect |
| CMN  |        | DM<br>PM<br>PM<br>P<br>P<br>PM[R] | , n<br>, n |   |   | •<br>•<br>• |     | •   |   | 1  |   |     |    |    |    | CMN<br>CMN<br>CMN<br>CMN<br>CMN<br>CMN        | DM0<br>PM0<br>PM1,2<br>P0<br>P0,2<br>PM[A] | Conditional, see flags.<br>Direct<br>Parameterized, list to follow.<br>As parameter.<br>As parameter, parameterized.<br>Indirect |
| CMAG |        | DM<br>PM<br>PM<br>P<br>P<br>PM[R] | , n<br>, n |   |   | •<br>•<br>• |     | •   |   | 0  |   |     |    | 1  |    | CMAG<br>CMAG<br>CMAG<br>CMAG<br>CMAG<br>CMAG  | DM0<br>PM0<br>PM1,2<br>P0<br>P0,2<br>PM[A] | Conditional, see flags.<br>Direct<br>Parameterized, list to follow.<br>As parameter.<br>As parameter, parameterized.<br>Indirect |
| CMMZ |        | DM<br>PM<br>PM<br>P<br>P<br>PM[R] | , n<br>, n |   |   | •<br>•<br>• |     | •   |   |    | 1 |     |    | 0  |    | CMMZ<br>CMMZ<br>CMMZ<br>CMMZ<br>CMMZ<br>CMMZ  | DM0<br>PM0<br>PM1,2<br>P0<br>P0,2<br>PM[A] | Conditional, see flags.<br>Direct<br>Parameterized, list to follow.<br>As parameter.<br>As parameter, parameterized.<br>Indirect |
| CMLG |        | DM<br>PM<br>PM<br>P<br>Fc[R]      | , n<br>, n |   |   | •<br>•<br>• |     | •   |   |    | 0 |     |    |    | 1  | CMLG<br>CMLG<br>CMLG<br>CMLG<br>CMLG<br>CMLG  | DM0<br>PM0<br>PM1,2<br>P0<br>P0,2<br>PM[A] | Conditional, see flags.<br>Direct<br>Parameterized, list to follow.<br>As parameter.<br>As parameter, parameterized.<br>Indirect |
| CMCZ |        | DM<br>PM<br>PM<br>P<br>P<br>PM[R] | , n<br>, n |   |   | • • • •     |     | •   |   |    | 0 |     |    |    | 0  | CMCZ<br>CMCZ<br>CMCZ<br>CMCZ<br>CMCZ<br>CMCZ  | DM0<br>PM0<br>PM1,2<br>P0<br>P0,2<br>PM[A] | Conditional, see flags.<br>Direct<br>Parameterized, list to follow.<br>As parameter.<br>As parameter, parameterized.<br>Indirect |

### 7.25 End of module instruction

End of module instructions may be executed unconditionally, and also in dependence on a binary link and/or a mathematical operation (see also Section 7.2 Flags).

| Con  | trolle | r instru | ction | R | G | Ad | dr. ty | ype |   |   |   | Flag | l |    |    | Example | Comment                 |
|------|--------|----------|-------|---|---|----|--------|-----|---|---|---|------|---|----|----|---------|-------------------------|
| OPP  | OPA    | SRC      | Z-OPD | А | Е | D  | R      | [R] | v | С | 0 | М    | z | AG | LG |         |                         |
| EM   |        |          |       |   |   |    |        |     |   |   |   |      |   |    |    | EM      | Unconditional           |
| EMC  |        |          |       |   |   |    |        |     | 1 |   |   |      |   |    |    | EMC     | Conditional, see flags. |
| BEI  |        |          |       |   |   |    |        |     | 0 |   |   |      |   |    |    | BEI     | Conditional, see flags. |
| EMCY |        |          |       |   |   |    |        |     |   | 1 |   |      |   |    |    | EMCY    | Conditional, see flags. |
| EMCN |        |          |       |   |   |    |        | ĺ   |   | 0 |   |      |   |    |    | EMCN    | Conditional, see flags. |
| EMO  |        |          |       |   |   |    |        |     |   |   | 1 |      |   |    |    | EMO     | Conditional, see flags. |
| EMON |        |          |       |   |   |    |        |     |   |   | 0 |      |   |    |    | EMON    | Conditional, see flags. |
| EEM  |        |          |       |   |   |    |        | ĺ   |   |   |   | 1    |   |    |    | EEM     | Conditional, see flags. |
| EMP  |        |          |       |   |   |    |        |     |   |   |   | 0    |   |    |    | EMP     | Conditional, see flags. |
| EMZ  |        |          |       |   |   |    |        |     |   |   |   |      | 1 |    |    | EMZ     | Conditional, see flags. |
| EMN  |        |          |       |   |   |    |        |     |   |   |   |      | 0 |    |    | EMN     | Conditional, see flags. |
| EMAG |        |          |       |   |   |    |        | ĺ   |   |   |   |      |   | 1  |    | EMAG    | Conditional, see flags. |
| EMMZ |        |          |       |   |   |    |        |     |   |   |   |      |   | 0  |    | EMMZ    | Conditional, see flags. |
| EMLG |        |          |       |   |   |    |        |     |   |   |   |      |   |    | 1  | EMLG    | Conditional, see flags. |
| EMCZ |        |          |       |   |   |    |        |     |   |   |   |      |   |    | 0  | EMCZ    | Conditional, see flags. |

### 7.26 FIFO instructions

The iPCL provides four FIFO buffers, designated FI0 through FI3.

Each FIFO buffer has a size of 1024 bytes.

Reading from and writing to the FIFO buffers is accomplished with the LFI and TFI instructions. A single instruction reads or writes 1 to 32 bytes.

The number of bytes to be handled by the LFI / TFI instruction is variable, and is specified in Register C.

# IF In the event that register contents are written to or read from FIFO buffers, the number of bytes will be defined via the operand attribute W/BY. Accordingly, operand attribute BY = one byte; operand attribute W = two bytes.

When the number of bytes to be handled is variably specified in register C, each FIFO byte that is read or written causes the value in register C to be decremented.

In the case of a FIFO buffer overflow or underflow, the value stored in register C provides information about the number of bytes that could no longer be read or written.

FIFO overflow or underflow will not automatically cause a ZS STOP. As an indication of a FIFO overflow, carry bit SM31.3 is set HIGH. A FIFO underflow causes zero bit SM31.7 to be set HIGH.

The FIFO buffer is flushed with the RFI (Reset FIFO) instruction.

### In the PNC all FIFOs are residual. In the osa master P-L/XL all FIFOs are not residual.

| Controller instruction |                  | R               | G                                          | Addr. |   |        | Flag |     |   |                          |   |   | Exai                     | nple                     | Comment          |                                        |                                                                                                                                         |
|------------------------|------------------|-----------------|--------------------------------------------|-------|---|--------|------|-----|---|--------------------------|---|---|--------------------------|--------------------------|------------------|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| OPP                    | OPA              | SRC             | Z-OPD                                      | А     | Е | D      | R    | [R] | V | CY                       | 0 | Ν | Z                        |                          |                  |                                        |                                                                                                                                         |
| LFI                    | B<br>W<br>D<br>R | Fln             | , M/S/SYM<br>, D/DX<br>, DF/DP<br>, OPD[R] |       |   | •<br>• | •    | •   |   | Ü:∙<br>Ü:∙<br>Ü:∙<br>Ü:• |   |   | U:•<br>U:•<br>U:•<br>U:• | LFI<br>LFI<br>LFI<br>LFI | B<br>B<br>W<br>D | FI2,Df30<br>FI3,D[A]<br>FI0,A<br>FI0,A | Read from FIFO buffer.<br>Number of bytes in C.<br>1 byte from FIFO into register A<br>2 bytes from FIFO into register A                |
| TFI                    | L<br>B<br>W      | M/S/SYM<br>D/DX | ,R<br>,Fln                                 |       |   | •      | •    | •   |   | Ü:∙<br>Ü:∙<br>Ü:∙        |   |   | U:•<br>U:•<br>U:•        | LFI<br>TFI<br>TFI        | B<br>B           | FI0,A<br>DF0,FI2<br>D[A],FI3           | 4 bytes from FIFO into register A<br>Write to FIFO buffer.<br>Number of bytes in C.                                                     |
|                        | D<br>R<br>L      | DF<br>[R]<br>R  |                                            |       |   | •      |      |     |   | Ü:∙<br>Ü:∙<br>Ü:∙        |   |   | U:•<br>U:•<br>U:•        | TFI<br>TFI<br>TFI        | B<br>W<br>D      | A,FI0<br>A,FI0<br>A,FI0                | <ol> <li>byte from register A into FIFO.</li> <li>bytes from register A into FIFO.</li> <li>bytes from register A into FIFO.</li> </ol> |
| RFI                    |                  | Fln             |                                            |       |   |        |      |     |   |                          |   |   |                          | RFI                      |                  | FI0                                    | Flush FIFO buffer.                                                                                                                      |

All FIFO instructions are RES-independent.

### 7.27 Block commands

Block commands are provided as a convenient means of loading and transferring and also comparing and searching data blocks within the iPCL. The maximum size of these data blocks is 512 bytes / 256 words / 128 double words. The operand attribute indicates whether the block size refers to byte, word, double word, REAL or LREAL size.

### IF The following minimum software version is a prerequisite for the use of the I and O operands in block commands: WinSPS 3.1

| Co           | ontrolle     | r instru                              | ction                                         | R | G | Addr.       |   |     | Flag |    |   |   |   | Exa             | ample                    | Comment                                                                          |
|--------------|--------------|---------------------------------------|-----------------------------------------------|---|---|-------------|---|-----|------|----|---|---|---|-----------------|--------------------------|----------------------------------------------------------------------------------|
| OPP          | OPA          | SRC                                   | Z-OPD                                         | А | Е | D           | R | [R] | V    | CY | 0 | Ν | z |                 |                          |                                                                                  |
| BLT          | B/W/D<br>R/L | M/S<br>I/O<br>D/DX<br>DP/DF<br>OPD[B] | , M/S<br>, O<br>, D/DX<br>, DP/DF<br>, OPD[A] |   |   | • • •       |   | •   |      |    |   |   |   | BLT E<br>BLT V  | 8 M0,D0<br>V DF[B], M[A] | Block transfer from SRC address<br>-> DEST address. Block size in<br>register C. |
| CFxx<br>CBxx | B/W/D        | M/S<br>I/O<br>D/DX<br>DP/DF<br>OPD[B] | , R<br>, O<br>, D/DX<br>, DP/DF<br>, OPD[A]   |   |   | • • • •     |   | •   |      |    |   |   | • | CFZ V<br>CBN E  | V MO,D0<br>8 M[B],D[C]   | Forward/ backward compare op-<br>eration within block.                           |
| SFxx<br>SBxx | B/W/D        | K<br>R                                | , R<br>, O<br>, D/DX<br>, DP/DF<br>, OPD[A]   |   |   | •<br>•<br>• |   | •   |      |    |   |   | • | SFZ V<br>SBLG E | V 50,M20<br>B B,M[A]     | Forward/ backward search opera-<br>tion within block.                            |

### **Block transfer**

Block transfers are accomplished by shifting data blocks of defined size, whereby the data blocks may not overlap. Block transfers use only ascending addresses (incremental).

#### Example 1:

| CM  |      | DM10     | ; | lst DM                                  |
|-----|------|----------|---|-----------------------------------------|
| BX  |      | DM9      | ; | 2nd DM                                  |
| L   | D    | 50,C     | ; | Block size = 50                         |
| BLT | W    | D20,DX40 | ; | Copy 50 words from DM9/D20 to DM10/D40. |
| Exa | mple | 2:       |   |                                         |
| т.  | П    | 50 A     |   | DEST address offset                     |

# L D 50,A ; DEST address offset L D 50,B ; SRC address offset L D 50,C ; Block size = 50 BLT D DF[B],M[A] ; Copy 50 double words from DF50 to M50.

### **Block COMPARE**

Compare two data blocks.

If the compare condition is met processing is stopped and the number of uncompared bytes / words written to register C. When using prefix addressing also the operand addresses are output to registers A and B. The zero flag is set to HIGH if the compare conditions were not met throughout the entire range.

Block compare operations are possible in forward direction on ascending addresses, and in backward direction on descending addresses.

By interpreting the flags C, M and Z and their respective combinations, 8 compare criteria are available.

| ОРР  | Description                                |
|------|--------------------------------------------|
|      | Compare forw. operation for the following: |
| CFZ  | Equal                                      |
| CFN  | Unequal                                    |
| CFAG | Arithmetical greater                       |
| CFM  | Arithmetical less                          |
| CFLG | Logical greater                            |
| CFCY | Logical less                               |
| CFCN | Logical greater or equal                   |
| CFCZ | Logical less or equal                      |
|      | Compare backw. operat. for the following:  |
| CBZ  | Equal                                      |
| CBN  | Unequal                                    |
| CBAG | Arithmetical greater                       |
| СВМ  | Arithmetical less                          |
| CBLG | Logical greater                            |
| CBCY | Logical less                               |
| CBCN | Logical greater or equal                   |
| CBCZ | Logical less or equal                      |

DEST block address direct or in register A, SRC block address direct or in register B, block size always in register C.

#### Example 1:

| CM       | DM10    | ; | 1st DM                                       |
|----------|---------|---|----------------------------------------------|
| L D      | 50,C    | ; | Block size = 50                              |
| CFLG W   | D20,M20 | ; | Compare forward 50 words for logical greater |
| ;        |         |   | starting at DM10/D20 with marker from M20.   |
| Example  | 0.      |   |                                              |
| слаттріе | Ζ.      |   |                                              |

### L D 50,A ; DEST address offset L D 50,B ; SRC address offset L D 50,C ; Block size = 50 CBZ D DF[B],M[A] ; Compare backward 50 double words for equal ; starting at DF50 with marker from M50.

Result evaluation of compare condition:

- Not met: Z-flag = 1
- Met: Z-flag = 0
  - In example 2 register A contains the operand address in the DEST block.
  - In example 2 register B contains the operand address in the SRC block.
  - Register C contains the count of data that was yet not compared.



### **Block search**

The function searches for a character within a data block.

If the character is found, the number of bytes / words that were not searched is stored in register C. With the use of prefix addressing, register A will also contain the operand address.

If the character was **not** found (search condition not met) throughout the entire range, the zero flag is set to HIGH.

Through the interpretation of flags C, M, and Z, and their respective combinations, 8 search criteria are available.

| OPP  | Description                    |
|------|--------------------------------|
|      | Search forward for character:  |
| SFZ  | Equal                          |
| SFN  | Unequal                        |
| SFAG | Arithmetical greater           |
| SFM  | Arithmetical less              |
| SFLG | Logical greater                |
| SFCY | Logical less                   |
| SFCN | Logical greater or equal       |
| SFCZ | Logical less or equal          |
|      | Search backward for character: |
| SBZ  | Equal                          |
| SBN  | Unequal                        |
| SBAG | Arithmetical greater           |
| SBM  | Arithmetical less              |
| SBLG | Logical greater                |
| SBCY | Logical less                   |
| SBCN | Logical greater or equal       |
| SBCZ | Logical less or equal          |

Block start address direct or in register A, search value as constant or in register B, block size always in register C.

#### Example 1:

```
L D 50,C
              ; Block size = 50
SFLG B 35,M20
              ; Search forward 50 bytes starting at M20
;
                 for the value 35.
Example 2:
CM
      DM10
L D 10,C ; Block size = 10
L D 50,B
              ; Search value
L D 20,A
               ; DEST address offset
SRZ D B,M[A]
                ; Search backward 10 bytes starting at M20 for
```

the value 50.

Result evaluation of search operation:

- Not met: Z-flag = 1
- Met: Z-flag and = 0
  - In example 2 register A contains the operand address of the searched operand range.
  - Register C contains the count of data that was yet not searched.

# 7.28 Interrupt instructions for time-controlled processing

| Cor | Controller instruction |     | iction | RG |   | Addr. |   |     |   | F  | -lag |   |   | Exa | mple | Comment                                                                                                                               |
|-----|------------------------|-----|--------|----|---|-------|---|-----|---|----|------|---|---|-----|------|---------------------------------------------------------------------------------------------------------------------------------------|
| OPP | OPA                    | SRC | Z-OPD  | А  | Е | D     | R | [R] | v | CY | 0    | Ν | z |     |      |                                                                                                                                       |
| TIM |                        | R   | , TI   |    |   | •     |   |     |   |    |      |   |   | ТІМ | A,TI | Transfers interrupt mask. Writes interrupt mask for<br>enabling / disabling interrupts.<br>The mask was first loaded into a register. |
| LIM |                        | TI  | , R    |    |   | •     |   |     |   |    |      |   |   | LIM | TI,B | Load interrupt mask, defined interrupt mask.                                                                                          |
| EAI |                        | TI  |        |    |   | •     |   |     |   |    |      |   |   | EAI | TI   | Enable interrupt group.                                                                                                               |
| DAI |                        | TII |        |    |   | •     |   |     |   |    |      |   |   | DAI | TI   | Disable interrupt group.                                                                                                              |
| LAI |                        | TII | , R    |    |   | •     |   |     |   |    |      |   |   | LAI | TI   | Load interrupt register<br>(read statuses).                                                                                           |
| RI  |                        | R   | , TI   |    |   | •     |   |     |   |    |      |   |   | RI  | A,TI | Reset interrupts based on a mask that was pre-<br>viously loaded.                                                                     |

### 7.29 Program stop and program end

| Cor | Controller instruction F |     |       | RG Addr. type |   |   |   |     | F | lag |   |   | Example | Comment |                                                                                                                                                  |
|-----|--------------------------|-----|-------|---------------|---|---|---|-----|---|-----|---|---|---------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| OPP | OPA                      | SRC | Z-OPD | А             | Е | D | R | [R] | V | CY  | 0 | Ν | z       |         |                                                                                                                                                  |
| HLT |                          |     |       |               |   |   |   |     |   |     |   |   |         | HLT     | Halt command<br>Controller enters STOP mode, program address is<br>entered into error stack and outputs are cleared<br>(deleted).                |
| PE  |                          |     |       |               |   |   |   |     |   |     |   |   |         | PE      | Program end.<br>I/O state is initialized and the program cycle starts<br>again at the beginning.<br>At least one EP instruction must be present. |

### BOSCH

### 7.30 Backing up and loading residual areas

Residual areas are dealt with using the following functions:

- **Backing up** residual iPCL data occurs by:
  - the program-controlled writing to the static RAM of the osa P-L/XL or
  - the automatic backup on shutdown to the hard disk of the base device via an area in dynamic RAM in the PNC.
- Loading residual data into the iPCL
  - from the static RAM of the osa P-L/XL or
  - from the hard disk (previously backed up there during the automatic shutdown (PNC))

The residual areas to be backed up or loaded correspond only to those data modules

• that have been identified by a residual identifier in the symbol file.

• Operands as per residual limits set in OM2.

See "Selection of residual data for cyclical backup" for iPCL page 3–12.

In the case of markers and the data field, specific areas of the defined residual area (Offset, Number) can be specified for the backup / loading procedures.

| C   | Controller instruction |                                | RG Addr. |   |   | Flag |   |     |   |    | Ex | ample | Comment |                                                                                                                   |                          |                                                                                                                                      |
|-----|------------------------|--------------------------------|----------|---|---|------|---|-----|---|----|----|-------|---------|-------------------------------------------------------------------------------------------------------------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| OPP | OPA                    | SRC                            | Z-OPD    | А | Е | D    | R | [R] | V | CY | 0  | Ν     | z       |                                                                                                                   |                          |                                                                                                                                      |
| RS  |                        | DMn<br>M,T,Z,<br>DF,DP<br>M,DF | OFF, Anz |   |   |      |   |     |   |    |    |       |         | RS<br>RS<br>RS<br>RS                                                                                              | DM1<br>M<br>DF<br>M10.50 | Back up DM1 to static RAM<br>or hard disk.<br>Back up residual area, as defined in OM2.<br>Residual from M10 up, backup of 50 bytes. |
| RL  |                        | DMn<br>M,T,Z,<br>DF,DP<br>M,DF | OFF, Anz |   |   |      |   |     |   |    |    |       |         | RL     DM1     Load DM1 from static RAM or disk.       RL     M     Load residual area as defined       RL     DF |                          | Load DM1 from static RAM or from hard                                                                                                |

# 8 **Processing Times**

### **iPCL** processing time

The iPCL processing time is the actual duration of program processing including the transfer of the I/O image to the bus master. Interruptions due to the interpolator and record change are included too.

### iPCL cycle time

Die iPCL cycle time is defined as the time that elapses from the start of a program until the start of the next one.

|           | System clock Sys  |           |                       |     |  |  |  |  |  |  |  |
|-----------|-------------------|-----------|-----------------------|-----|--|--|--|--|--|--|--|
| OM1<br>PE |                   | I/O image | Rest of system        | OM1 |  |  |  |  |  |  |  |
| -         | iPCLproce<br>time | essing 🔶  |                       |     |  |  |  |  |  |  |  |
| <b>-</b>  |                   |           | ── iPCL cycle time ── |     |  |  |  |  |  |  |  |

### Ratio of iPCL system clock to rest of system (Windows)

The PCL cycle time is started in a fixed time matrix that can be set in MA-CODA parameter 2060 00202.

In the MACODA parameter 2060 00211 the maximum proportion of processing time for the iPCL can be set. Up to how many percent of the total available computing time iPCL can take is set with this parameter. (Default value: 30%). If the PCL program exceeds this value, a warning message is generated indicating that the PCL program has left too little processing time for the rest of the system. Then either the time matrix of PCL starts must be increased or, if possible, the processing time of the PCL program must be decreased. iPCL continues to run during this. Notes:

# 9 Sample Programs

# 9.1 Indirect addressing

|                  |                  |                 | ; DM checking whether<br>; a) DM1-DM16 are present and<br>; b) generating "existence bits" in result DM0/D0<br>; c) Writing DM sizes into result DM starting with D2 |
|------------------|------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| L<br>L<br>L<br>L | D<br>D<br>D<br>D | 0,B             | ; Starting with DM1<br>; DM existence bits in result DM in D0<br>; DM sizes in result DM starting with D2<br>; DM no. of result DM                                   |
| СМ               | DM[D]            |                 | ; Result DM indirect module call                                                                                                                                     |
| not_r<br>U<br>=  | eady:<br>ssing)  | DM [A]<br>D [B] | ; Check DMs and write results<br>; Check DM, indirect module existence check<br>; If applicable, set existence bit HIGH (ind. bit                                    |
| PUSH             | 5                | А               | : Save DM no.                                                                                                                                                        |
|                  | D                |                 | ; Load DM size (indirect module size check)                                                                                                                          |
|                  | W                |                 | ; Write to size word (indirect double word addressing)                                                                                                               |
| POP              |                  |                 | ; Write back DM no.                                                                                                                                                  |
| 101              | 2                |                 | ; Increment address                                                                                                                                                  |
| INC              | D                | A,1             | ; Next DM                                                                                                                                                            |
| INC              | D                |                 | ; Next DM existence bit                                                                                                                                              |
| INC              | D                | C,2             | ; Next DM size word                                                                                                                                                  |
|                  |                  |                 | ; All 16 DMs specified processed?                                                                                                                                    |
| CPLA             | D                | 16,A            |                                                                                                                                                                      |
| JPCZ<br>EM       | not_re           | ady ; ju        | mp on less than or equal                                                                                                                                             |

# 9.2 Compare instruction examples

|                        |                                 |          | ; Simuated compare value                                                              |
|------------------------|---------------------------------|----------|---------------------------------------------------------------------------------------|
| L<br>INC<br>T          | W MO,A<br>W A,1<br>W A,MO       |          | ;<br>; Load markers M0-M1<br>; Increment register<br>; Write value into markers M0-M1 |
|                        |                                 |          | ; 1. Compare for "equal"<br>;                                                         |
|                        | W M0,A<br>W 10000,A             |          | ; Current M0-M1 status<br>; Value 10,000 reached?                                     |
| U<br>CU                | Z<br>Z 0                        |          | ; Interpretation via links<br>; Value 10,000 reached!<br>; Increment counter Z0 by 1  |
|                        |                                 |          | ; Interpretation via jump instruction                                                 |
| JPN<br>L<br>T<br>not_0 | nicht_0<br>W 0,A<br>W A,M0<br>: |          | ; Upon attaining the value 10,000<br>; delete MO-M1                                   |
|                        |                                 |          |                                                                                       |
|                        |                                 |          | ; 2. Range monitoring<br>;                                                            |
|                        |                                 |          | ; Check value range 4000-6000                                                         |
| JPCY                   | W 4000,A<br>Bereich_niO         |          | ; Value must not be less than 4000                                                    |
|                        | W 6000,A<br>Bereich_niO         |          | ; and not greater than 6000                                                           |
|                        |                                 |          | ; Increment marker M2 in value window                                                 |
| 4000-<br>L             | 6000<br>D M4,B                  |          | ; Load markers M4-M7                                                                  |
| INC<br>T               | D B,100<br>D B,M4               |          | ; Increment register<br>; Write value to markers M4-M7                                |
| Area_                  | nok:                            |          |                                                                                       |
|                        |                                 |          |                                                                                       |
|                        | -RI_Anl<br>no RI                |          | ; delete markers MO-M1 and counter CO with ; trigger pulse                            |
| L                      | D 0,A                           |          | ; Write value 0                                                                       |
| T<br>SC                | W A,MO<br>A,ZO                  | ; and T0 | ; to markers MO-M1                                                                    |
| T<br>no_RI<br>EM       | D A,M4                          |          | ; on markers M4-M7                                                                    |

# 9.3 FIFO instruction examples

| DEF<br>DEF<br>DEF<br>DEF<br>DEF<br>DEF | SM31.1,-log1<br>SM31.6,-carry<br>SM31.7,-zero<br>M0.0,-trouble<br>M2.0,-nofifo<br>M6,-rest<br>M8.0,-RFI |                                                                                           |
|----------------------------------------|---------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
|                                        |                                                                                                         | ; Tranferring data into a FIFO buffer:                                                    |
| BX                                     | -db5                                                                                                    | ; Open data module                                                                        |
| A<br>JPB                               | -nofifo<br>end                                                                                          | ; FIFO instruction locked?<br>; Then no transfer to FIFO                                  |
| L W                                    | K30D,C                                                                                                  | ; 30 bytes from the second active<br>; DM                                                 |
| TFI E<br>FIFO FI                       | ,                                                                                                       | ; starting with D10 to be transferred to                                                  |
| А                                      | -log1                                                                                                   | ; Lock FIFO instruction to prevent<br>; repeat execution                                  |
| S                                      | -nofifo                                                                                                 | , repeat execution                                                                        |
| A<br>O<br>S<br>JPCI                    | -carry<br>-zero<br>-trouble<br>nosave                                                                   | ; FIFO overflow?<br>; FIFO underflow?                                                     |
| T W<br>count                           |                                                                                                         | ; In case of an overflow / underflow the                                                  |
| nosave:                                |                                                                                                         | ; of the remaining data that could not be<br>; transferred is written to<br>; register C. |
| L W<br>end:                            | и с,с                                                                                                   | ; Monitor help                                                                            |
| A<br>JPCI                              | -RFI<br>noreset                                                                                         | ; Delete FIFO:<br>; Delete locked?                                                        |
| RFI                                    | FI3                                                                                                     | ; Delete FIFO FI3                                                                         |
| A E<br>R E<br>noreset                  | B -RFI                                                                                                  | ; Lock delete sequence to prevent<br>; repeat execution.                                  |

Notes:

# A Appendix

## A.1 Abbreviations

| Abbreviation | Description                                                                                                                                 |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| BOF          | Bosch Standard User Interface                                                                                                               |
| DM           | Data module                                                                                                                                 |
| DRAM         | Dynamic Random Access Memory                                                                                                                |
| EM           | End of module                                                                                                                               |
| EP           | End of program                                                                                                                              |
| ESD          | Electro-Static Discharge<br>Abbreviation for all terms relating to elec-<br>tro-static discharge, e.g. ESD protection,<br>ESD hazards, etc. |
| FBD          | Function Block Diagram                                                                                                                      |
| IL           | Instrction List, programming language                                                                                                       |
| LD           | Ladder Diagram, programming language                                                                                                        |
| OM           | Organisation module                                                                                                                         |
| PM           | Program modules                                                                                                                             |
| RAM          | Random Access Memory                                                                                                                        |
| SFC          | Sequential Function Chart                                                                                                                   |
| SRAM         | Static Random Access Memory                                                                                                                 |
| ST           | Structured Text, programming language                                                                                                       |
| TCP/IP       | Transmission Control Protocol / Internet<br>Protocol                                                                                        |
| UPS          | Uninterruptible power supply                                                                                                                |

### A.2 Index

### Α

Absolute value, forming, 7–29 Active ID, 6–7 ADD instructions, 7–18 Addressing Register – Register, 6–14 Register indirect, 6–15 Addressing Conventions, 6–1 Addressing limits, 6–19 Addressing modes, 6–14 application program, Program structure, 5–7 Application stack, 5–20 APS modules, 5–4 Auxiliary markers for program tracking., 7–31

### В

Bit, Data format, 6–7 Bit and module addresses, 6–13 Bit instructions, 7–3 Block commands, 7–38 BMF, 6–6 Buffer failure, 3–16 Bus master error, 6–6 Byte, Data format, 6–7 Byte addresses, 6–13

### С

CARRY manipulations, 7–15 Cold start flag, 3–6 COMPARE instruction, 7–10 Example, 9–2 Constants, Representation, 6–12 Controller instruction, Construction, 7–1 CONVERT data formats, 7–26 CONVERT instructions, 7–14 CONVERT number formats, 7–26 Counter instructions, 7–8

### D

Data backup, 3–9 Data backup error, 3–16 Data exchange machine, 4–1 Data formats, 6–7 Data modules, 5–3 Decimal positions, removing, 7–27 Digital links, 7–9 DIVIDE instructions, 7–23 Documentation, 1–7 Double word, Data format, 6–9

### Е

EMC Directive, 1–1 EMERGENCY–STOP devices, 1–5 End of module instruction, 7–36 ESD Electrostatic discharge, 1–6 grounding, 1–6 workplace, 1–6 ESD-sensitive components, 1–6 Exponentiation, 7–29

### F

FBD, 5-1 FEPROM, osa master P-L/XL (SNCI4), 2-5 FIFO instructions, 7-37 Example, 9-3 Fixation, 5-17 Inputs, outputs and markers, 5-6 Residual, 5-17 Fixed point arithmetic, 7-18 Flags, 7-1 Floating point arithmetic , 7-24 Floating point values calculating with, 7-28 Compare, 7-27 Load, 7-25 Transfer, 7-26 Floppy disk drive, 1-7 Function Block Diagram, 5-1 Functional security, UPS (osa master P-L/XL), 3-11 Functionality, iPCL, 2-1

### G

Grounding bracelet, 1-6

### Н

Hard disk drive, 1–7 Hardware platforms, 2–2

### I

I/O state, 5-6 IL, 5–1 **INCREMENT & DECREMENT instructions, 7-15** Indirect addressing, 6-16 Examples, 9-1 Indirect bit addresses, 6-17 Indirect byte addresses, 6-17 Indirect module addresses, 6-17 Initial start, Exceptions, 3-3 Initialization, 3-3 Initialization values, 3-3 Initializing special markers, 3-3 Instruction list, IL, 5-1 Instruction set, 7-1 Interrupt instructions, for time-controlled processing, 7-41 iPCL extensions, 2-3 iPCL in PNC, 2-2 iPCL in the osa master P-L/XL (Typ3 osa), 2-2

### J

Jump instructions, 6-12, 7-32

### Κ

KSD, 6–6

### L

Ladder Diagram, 5–1 LD, 5–1 LOAD instructions, 7–12 Local symbol names, 7–31 Logarithmic functions, 7–30 Low–Voltage Directive, 1–1

### Μ

MACODA, Registering the iPCL, 3–1 Memory types, osa master P–L/XL (SNCI4), 2–5 Module calls, 7–34 Module existence, 5–15 Module header, 5–16 Module list, 6–1 Module reference list, 5–14 Module size, 5–15 Module start address, 5–16 Module Types, 5–2 Modules, Parameterized, 5–18 Modules sensitive to electrostatic discharge. *See* ESD– sensitive components MULTIPLY instructions, 7–22

### Ν

New start non-residual, 3–8 residual, 3–8 No operations, 7–15 Non-residual operation, 3–15

### 0

OM2, Initialisation table, 5–8 OM2iPCL, Printout, 5–9 OM5, New start OM, 3–5 OM7, Restart OM, 3–5 OM9, Error module, 5–17 OPC server functions, 2–3 Operand & module identifiers, 6–1 Operands (absolute addressable), 6–14 Direct addressing, 6–14 Organization modules (OM), 5–2

### Ρ

Parameter assignments, 7-31 Parameter transfer, 6-18 Peripheral Operation, 4-1 Periphery status, 6-6 Processing Times, 8-1 PROFIBUS-DP, 4-2 Configuration, 4-2 Data consistency, 4-2 Data exchange, 4-2 Interfacing with the hardware platform, 3-1 Peripheral errors, 4–2 Properties, 4-2 Program module calls, 6-12 Program modules, 5-3 Program processing cyclical, 5-5 time-controlled, 5-5, 5-19

Program stop and program end, 7–41 Program Structure, 5–2 Programming, 5–1

### Q

Qualified personnel, 1-2

### R

Register structure, 6–11 Register-to-register addressing, 6–14 Release, 1–8 Residual areas backing up and loading, 7–42 OB2, 3–12 Residual characteristics, Hardware platforms, 3–14 Residual data, Selection for cyclical backup, 3–12 Residual operation, 3–15 Restart non-residual, 3–8 residual, 3–8 ROTATE instructions, 7–17

### S

Safety instructions, 1-4 Safety markings, 1-3 Sample Programs, 9-1 SD, 6-7 SDRAM osa master P-L/XL (SNCI4), 2-5 PNC, 2-4 Sequential Function Chart, 5-1 SFC. 5-1 SHIFT instructions, 7-16 Slave diagnostics (classified), KSD, 6-6 Spare parts, 1-6 Special marker area, Assignment, 6-2 Square root, extracting, 7-29 SRAM, osa master P-L/XL (SNCI4), 2-5 ST, 5-1 STACK instructions, 7-15 Standard operation, 1-1 Startup, 3-4 overview, 3-2 with processing STOP, 3-8 with startup STOP, 3-7 without error, 3-7 Startup characteristics, 3-5 Startup conditions, 3-4 Structured Text, 5-1 SUBTRACT instructions, 7-20 SWAP instructions, 7-9 Switch setting S1, 3-4 System area, Assignment, 6-4 System clock management, 3-1 System configuration, 3-1 System diagnostics, SD, 6-7 System Overview, 2-1 System variable, 7-31

#### Т

Test activities, 1-5





Time format, 7–6 Time Monitoring, 5–6 Timer diagrams, 7–7 Timer instructions, 7–5 Timer programming, 7–4 Times, Updates, 5–7 Trademarks, 1–8 TRANSFER instructions, 7–13 Trigonometric functions floating point, 7–30

### w

Word, Data format, 6-8

# **Bosch Automation Technology**

### Australia

Robert Bosch (Australia) Pty. Ltd. Head Office Cnr. Centre - McNaughton Roads P.O. Box 66 AUS-3168 Clayton, Victoria Fax (03) 95 41 77 03

### Great Britain

Robert Bosch Limited Automation Technology Division Meridian South Meridian Business Park GB-Braunstone Leicester LE3 2WY Fax (01 16) 289 2878

### Canada

Robert Bosch Corporation Automation Technology Division 6811 Century Avenue CAN-Mississauga, Ontario L5N 1R1 Fax (905) 5 42-42 81

### USA

Robert Bosch Corporation Automation Technology Division Fluid Power Products 7505 Durand Avenue USA-Racine, Wisconsin 53406 Fax (414) 5 54-81 03

Robert Bosch Corporation Automation Technology Division Factory Automation Products 816 East Third Street USA-Buchanan, MI 49107 Fax (616) 6 95-53 63

Robert Bosch Corporation Automation Technology Division Industrial Electronic Products 40 Darling Drive USA-Avon, CT 0 60 01-42 17 Fax (860) 4 09-70 80

We reserve the right to make technical alterations

Your concessionary

BOSCH



Robert Bosch GmbH Geschäftsbereich Automationstechnik Antriebs- und Steuerungstechnik Postfach 11 62 D-64701 Erbach Fax +49 (0) 60 62 78-4 28

1070 073 875-101 (02.04) GB · HB NC · BRC/ESM11 · Printed in Germany